我的编程空间,编程开发者的网络收藏夹
学习永远不晚

面试JavaScript的题目是怎样的

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

面试JavaScript的题目是怎样的

面试JavaScript的题目是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

  1、怎样添加、移除、移动、复制、创建和查找节点?

  1)创建新节点

  createDocumentFragment() //创建一个DOM片段

  createElement() //创建一个具体的元素

  createTextNode() //创建一个文本节点

  2)添加、移除、替换、插入

  appendChild() //添加

  removeChild() //移除

  replaceChild() //替换

  insertBefore() //插入

  3)查找

  getElementsByTagName() //通过标签名称

  getElementsByName() //通过元素的Name属性的值

  getElementById() //通过元素Id,唯一性

  2、实现一个函数clone,可以对JavaScript中的5种主要的数据类型(包括Number、String、Object、Array、Boolean)进行值复制。

  

  functionclone(obj){

  varo;

  switch(typeof obj){

  case"undefined":

  break;

  case"string":

  o = obj + "";

  break;

  case"number":

  o = obj - 0;

  break;

  case"boolean":

  o = obj;

  break;

  case"object": // object 分为两种情况 对象(Object)或数组(Array)

  if(obj === null){

  o = null;

  }else{

  if(Object.prototype.toString.call(obj).slice(8, -1) === "Array"){

  o = [];

  for(vari = 0;i obj.length;i++){

  o.push(clone(obj[i]));

  }

  }else{

  o = {};

  for(varkinobj){

  o[k] = clone(obj[k]);

  }

  }

  }

  break;

  default:

  o = obj;

  break;

  }

  returno;

  }

  3、如何消除一个数组里面重复的元素?

  // 方法一:

  vararr1 =[1,2,2,2,3,3,3,4,5,6],

  arr2 = [];

  for(vari = 0,len = arr1.length;i< len;i++){

  if(arr2.indexOf(arr1[i]) < 0){

  arr2.push(arr1[i]);

  }

  }

  document.write(arr2);// 1,2,3,4,5,6

  4、想实现一个对页面某个节点的拖曳?如何做?(使用原生JS)。

  5、在Javascript中什么是伪数组?如何将伪数组转化为标准数组?

  伪数组(类数组):无法直接调用数组方法或期望length属性有什么特殊的行为,但仍可以对真正数组遍历方法来遍历它们。典型的是函数的argument参数,还有像调用getElementsByTagName,document.childNodes之类的,它们都返回NodeList对象都属于伪数组。可以使用Array.prototype.slice.call(fakeArray)将数组转化为真正的Array对象。

  functionlog(){

  varargs = Array.prototype.slice.call(arguments);

  //为了使用unshift数组方法,将argument转化为真正的数组

  args.unshift('(app)');

  console.log.apply(console,args);

  };

  6、Javascript中callee和caller的作用?

  caller是返回一个对函数的引用,该函数调用了当前函数;

  callee是返回正在被执行的function函数,也就是所指定的function对象的正文。

  7、请描述一下cookies,sessionStorage和localStorage的区别

  sessionStorage用于本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问并且当会话结束后数据也随之销毁。因此sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储。而localStorage用于持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的。

  web storage和cookie的区别

  web Storage的概念和cookie相似,区别是它是为了更大容量存储设计的。Cookie的大小是受限的,并且每次你请求一个新的页面的时候Cookie都会被发送过去,这样无形中浪费了带宽,另外cookie还需要指定作用域,不可以跨域调用。

  除此之外,web Storage拥有setItem,getItem,removeItem,clear等方法,不像cookie需要前端开发者自己封装setCookie,getCookie。但是Cookie也是不可以或缺的:Cookie的作用是与服务器进行交互,作为HTTP规范的一部分而存在 ,而web Storage仅仅是为了在本地“存储”数据而生。

  8、手写数组快速排序

  关于快排算法的详细说明,可以参考阮一峰老师的文章快速排序

  “快速排序”的思想很简单,整个排序过程只需要三步:

  (1)在数据集之中,选择一个元素作为”基准”(pivot)。

  (2)所有小于”基准”的元素,都移到”基准”的左边;所有大于”基准”的元素,都移到”基准”的右边。

  (3)对”基准”左边和右边的两个子集,不断重复第一步和第二步,直到所有子集只剩下一个元素为止。

  9、统计字符串”aaaabbbccccddfgh”中字母个数或统计最多字母数。

  varstr = "aaaabbbccccddfgh";

  varobj = {};

  for(vari=0;istr.length;i++){

  varv = str.charAt(i);

  if(obj[v] & obj[v].value == v){

  obj[v].count = ++ obj[v].count;

  }else{

  obj[v] = {};

  obj[v].count = 1;

  obj[v].value = v;

  }

  }

  for(key inobj){

  document.write(obj[key].value +'='+obj[key].count+' ');// a=4 b=3 c=4 d=2 f=1 g=1 h=1

  }

  10、写一个function,清除字符串前后的空格。(兼容所有浏览器)

  functiontrim(str){

  if(str & typeof str === "string"){

  returnstr.replace(/(^s*)|(s*)$/g,"");//去除前后空白符

  }

  }

关于面试JavaScript的题目是怎样的问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网行业资讯频道了解更多相关知识。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

面试JavaScript的题目是怎样的

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

哦?原来Python 面试题是这样的,P

本面试题题库,由公号:非本科程序员 整理发布第1题:是否遇到过python的模块间循环引用的问题,如何避免它?这是代码结构设计的问题,模块依赖和类依赖如果老是觉得碰到循环引用可能的原因有几点:可能是模块的分界线划错地方了可能是把应该在一起的
2023-01-31

JavaScript中关于“this”的面试题

这篇文章将为大家详细讲解有关JavaScript中关于“this”的面试题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在 JavaScript 中,this 是函数调用上下文。正是由于 this 的行为
2023-06-14

Java的基础面试题目(3)

String s = new String("xyz");创建了几个StringObject?是否可以继承String类?两个或一个都有可能,”xyz”对应一个对象,这个对象放在字符串常量缓冲区,常量”xyz”不管出现多少遍,都是缓冲区中的那一个。
Java的基础面试题目(3)
2018-01-28

Java的基础面试题目(2)

11、是否可以从一个static方法内部发出对非static方法的调用?不可以。因为非static方法是要与对象关联在一起的,必须创建一个对象后,才可以在该对象上进行方法调用,而static方法调用时不需要创建对象,可以直接调用。
Java的基础面试题目(2)
2019-02-27

Java的基础面试题目(1)

1、一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制?可以有多个类,但只能有一个public的类,并且public的类名必须与文件名相一致。 (推荐学习:java面试题目)2、Java有没有goto? java中的保留字,现在没有在
Java的基础面试题目(1)
2016-11-11

Java的基础面试题目(4)

a.hashCode() 有什么用?与 a.equals(b) 有什么关系?hashCode() 方法对应对象整型的 hash 值。它常用于基于 hash 的集合类,如 Hashtable、HashMap、LinkedHashMap等等。它与 equals()
Java的基础面试题目(4)
2020-03-09

常见的JavaScript面试题有哪些

这篇文章主要介绍常见的JavaScript面试题有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!JavaScript可以做什么1.可以使网页具有交互性,例如响应用户点击,给用户提供更好的体验。2.可以处理表单,检
2023-06-14

有哪些常见的JavaScript面试题

今天就跟大家聊聊有关有哪些常见的JavaScript面试题,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.this指向1.谁调用指向谁例: function foo(){
2023-06-15

JavaScript的面试问答题有哪些

本篇内容介绍了“JavaScript的面试问答题有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!JavaScript的数据类型都有什么?
2023-06-27

java集合的区别面试题目

HashMap 和 Hashtable 有什么区别?HashMap 和 Hashtable 都实现了 Map 接口,因此很多特性非常相似。但是,他们有以下不同点: HashMap 允许键和值是 null,而 Hashtable 不允许键或者值是 null。
java集合的区别面试题目
2014-07-02

编程热搜

目录