文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

面试JavaScript的题目是怎样的

2024-04-02 19:55

关注

面试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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯