前端javascript知识(二)

  • documen.write和 innerHTML的区别

    document.write只能重绘整个页面
    innerHTML可以重绘页面的一部分
  • 浏览器检测通过什么?
    (1) navigator.userAgent
    (2) 不同浏览器的特性,如addEventListener
  • JavaScript有哪几种数据类型?
    简单,Number,Boolean,String,Null,Undefined
    复合,Object,Array,Function
  • 截取字符串“abcdefghi”的“fghi”
    var myvalue=”abcdefghi”;
    var jiequ=myvalue.substring(myvalue.length-4,myvalue.length);
    alert(jiequ);

    -写出下面的运算结果

    alert(typeof(null)); // object
    alert(typeof(undefined)); // undefined
    alert(typeof(NaN)); // number
    alert(NaN==undefined); // false
    alert(NaN==NaN); // false
    var str="123abc";
    alert(typeof(str++)); // number
    alert(str);// NaN
  • 问执行完毕后 x, y, z 的值分别是多少?
    var x = 1, y = z = 0;
    function add(n) {
      n = n+1;
    }
    y = add(x);
    function add(n) {
      n = n + 3;
    }
    z = add(x);
    1、undefined、undefined
  • 如何阻止事件的冒泡?
    //阻止冒泡的方法
    function stopPP(e)
    {
      var    evt = e|| window.event;
      //IE用cancelBubble=true来阻止而FF下需要用stopPropagation方法
      evt.stopPropagation ?evt.stopPropagation() : (evt.cancelBubble=true);
    }
  • 写出程序运行的结果?
    for(var i=0, j=0; i<10, j<6; i++, j++){
      k = i + j;
    }
    10
  • 编写一个方法 求一个字符串的字节长度
    /*假设:一个英文字符占用一个字节,一个中文字符占用两个字节*/
    function getBytes(str){
      var len = str.length,
          bytes = len,
          i = 0;
      for(; i<len; i++){
          if (str.charCodeAt(i) > 255) bytes++;
      }
      return bytes;
    }
    alert(getBytes("玩,as"));
  • JavaScript中如何对一个对象进行深度clone?
    function cloneObject(o) {
      if(!o || ‘object‘ !== typeof o) {
          return o;
      }
      var c = ‘function‘ === typeof o.pop ? [] : {};
      var p, v;
      for(p in o) {
          if(o.hasOwnProperty(p)) {
              v = o[p];
              if(v && ‘object‘ === typeof v) {
                  c[p] = Ext.ux.clone(v);
              }
              else {
                  c[p] = v;
              }
          }
      }
      return c;
    };
  • 如何控制alert中的换行?
    \n alert(“p\np”);
  • 请编写一个JavaScript函数 parseQueryString,它的用途是把URL参数解析为一个对象,如:
    var url = “http://witmax.cn/index.php?key0=0&key1=1&key2=2″;
    function parseQueryString(url){
      var params = {},
          arr = url.split("?");
      if (arr.length <= 1)
          return params;
      arr = arr[1].split("&");
      for(var i=0, l=arr.length; i<l; i++){
          var a = arr[i].split("=");
          params[a[0]] = a[1];
      }
      return params;
    }
    var url = "http://witmax.cn/index.php?key0=0&key1=1&key2=2",
      ps = parseQueryString(url);
    console.log(ps["key1"]);
  • 如何控制网页在网络传输过程中的数据量?
    启用GZIP压缩
    保持良好的编程习惯,避免重复的CSS,JavaScript代码,多余的HTML标签和属性
  • 以下代码运行结果
    function say() {
     // Local variable that ends up within closure
     var num = 888;
     var sayAlert = function() { alert(num); }
     num++;
     return sayAlert;
    }
    var sayAlert = say();
    sayAlert();//889
  • 请实现ECMAScript 5中的Object.getPrototypeOf() 函数
    function proto(object) {
      return !object?                null
          : ‘__proto__‘ in object?  object.__proto__
          : /* not exposed? */      object.constructor.prototype
    }
  • 如何实现Array.prototype.forEach?
    if (!Array.prototype.forEach) {
      Array.prototype.forEach = function(fn){
          for ( var i = 0; i < this.length; i++ ) {
              fn( this[i], i, this );
          }
      };
    }
    ["a", "b", "c"].forEach(function(value, index, array){
      assert( value, "Is in position " + index + " out of " + (array.length - 1) );
    });
  • 如何将arguments转为数组?
    Object.prototype.slice.call(arguments);
  • 以下程序运行结果?
    var ninja = function myNinja(){
      alert(ninja == myNinja);
    };
    ninja();
    myNinja();
    true、报错(error - myNinja is not defined.)
  • 如何获取光标的水平位置?
    function getX(e){
      e = e || window.event;
      //先检查非IE浏览器,在检查IE的位置
      return e.pageX || e.clentX + document.body.scrollLeft;
    }
  • 兼容浏览器的获取指定元素(elem)的样式属性(name)的方法
    function getStyle(elem, name){
      if(elem.style[name]){//如果属性存在于style[]中,直接取
          return elem.style[name];
    }
    else if(elem.currentStyle){//否则 尝试IE的方法
          return elem.currentStyle[name];
    }//尝试W3C的方式
    else if(document.defaultView && document.defaultView.getComputedStyle){
          name = name.replace(/([A-Z])/g, "-$1");//W3C中为textAlign样式,转为text-align
          name = name.toLowerCase();
          var s = document.defaultView.getComputedStyle(elem, "");
          return s && s.getPropertyValue(name);
      }else{
          return null;
      }
    }
  • Javascript中实现类似PHP的print_r函数
    function print_r(theObj) {
      var retStr = ‘‘;
       if(typeof theObj == ‘object‘) {
            retStr += ‘<div style="font-family:Tahoma; font-size:7pt;">‘;
            for(var p in theObj) {
                  if (typeof theObj[p] == ‘object‘) {
                        retStr += ‘<div><b>[‘+p+‘] => ‘ + typeof(theObj) + ‘</b></div>‘;
                        retStr += ‘<div style="padding-left:25px;">‘ +  print_r(theObj[p]) + ‘</div>‘;
                  } else {
                        retStr += ‘<div>[‘+p+‘] => <b>‘ + theObj[p] +  ‘</b></div>‘;
                  }
             }
            retStr += ‘</div>‘;
        }
        return  retStr;
    }
  • 以下程序运行结果?
    var b = parseInt("01");
    alert("b="+b);
    var c = parseInt("09/08/2009");
    alert("c="+c);
    b=1、c=0。
  • 以下程序的运行结果?
    var foo = ‘hello‘;
    (function() {
         var foo= foo || ‘world‘;
         console.log(foo);
    })();
    world
  • 如何规避javascript多人开发函数重名问题?
    (1) 可以开发前规定命名规范,根据不同开发人员开发的功能在函数前加前缀
    (2) 将每个开发人员的函数封装到类中,调用的时候就调用类的函数,即使函数重名只要类名不重复就行
  • 前端开发有哪些优化问题?
    减少http请求次数:cssspirit,data uri
    JS,CSS源码压缩
    前端模板JS+数据,减少由于HTML标签导致的带宽浪费,前端用变量保存AJAX请求结果,每次操作本地变量,不用请求,减少请求次数
    用innerHTML代替DOM操作,减少DOM操作次数,优化javascript性能
    用setTimeout来避免页面失去响应
    用hash-table来优化查找
    当需要设置的样式很多时设置className而不是直接操作style
    少用全局变量
    缓存DOM节点查找的结果
    避免使用CSS Expression
    图片预载
    避免在页面的主体布局中使用table,table要等其中的内容完全下载之后才会显示出来,显示比div+css布局慢
  • AJAX请求总共有多少种CALLBACK
    Ajax请求总共有八种Callback
    onSuccess
    onFailure
    onUninitialized
    onLoading
    onLoaded
    onInteractive
    onComplete
    onException
  • 请给出异步加载js方案,不少于两种
    异步加载方式:
    defer,只支持IE
    async:
    创建script,插入到DOM中,加载完毕后callBack,见代码:
    function loadScript(url, callback){
        var script = document.createElement("script")
        script.type = "text/javascript";
        if(script.readyState){ //IE
            script.onreadystatechange = function(){
                 if (script.readyState == "loaded" ||script.readyState == "complete"){
                        script.onreadystatechange = null;
                        callback();
                 }
           };
       } else {
    //Others: Firefox, Safari, Chrome, and Opera
           script.onload = function(){
              callback();
           };
      }
      script.src = url;
      document.body.appendChild(script);
    }
时间: 2024-11-13 00:30:40

前端javascript知识(二)的相关文章

前端javascript知识(三)

函数记忆,判断是不是质数. 方法一: function isPrime1(n){ if(n<=3){return true} else{ for(var i=2;i<Math.sqrt(n);i++){ if(n%i==0){return false;} } return true; } }; 方法二:hash var isPrime2=(function(){//hash var hash={}; return function(n){ if(n<=3){return true} el

小猿圈之2019年前端JavaScript面试题(二)

小猿圈前端讲师今天继续给你总结js面试题,前面一篇文章咱们已经有一片js基础部分面试题,今天小猿圈web讲师为你讲解js前端应用设计问题,一定要好好看哦,为了能赢在其他人前面. JavaScript前端应用设计问题 1.解释单向数据流和双向数据绑定. Angular1.x基于双向数据绑定,而React,Vue,Elm等基于单向数据流架构. 2.单向数据流架构在哪些方面适合MVC? MVC拥有大约50年的悠久历史,并已演变为MVP,MVVM和MV*.两者之间的相互关系是什么?如果MVC是架构模式,

菜鸟学前端--javascript基础

在学习过css相关的知识,有了前端工程师的一些基础知识.但要较好的掌握前端,必须要学习好javascript的知识. 下面将从基本语法.变量.关键字.保留字.语句.函数.BOM等角度阐释. 一.基本语法 javacript作为一种面向对象的.脚本级的轻量语言,与java一脉相承. 命名:区分大小写,弱类型定义(一般采用var,不限制类型). 行末分号可有可无(从经验上来看,推荐写,可以提高代码阅读质量). 括号用于代码段. 注释与C.java类型,单行用"//",段注释用"/

web前端工程师知识汇总

分类: Web开发应用 一.何为Web前端工程师? 前端工程师,也叫Web前端开发工程师.他是随着web发展,细分出来的行业.Web前端开发工程师,主要职责是利用(X)HTML/CSS/JavaScript/DOM/Flash等各种Web技术进行产品的界面开发.制作标准优化的代码,并增加交互动态功能,开发JavaScript以及Flash模块,同时结合后台开发技术模拟整体效果,进行丰富互联网的Web开发,致力于通过技术改善用户体验. Web前端工程师成长之路--知识汇总 图1.前端技术MSS W

前端JavaScript面试技巧

第1章 课程简介从几个常见面试开始,讨论针对一个题目的分析思路,总结题目对应的知识点.最后列出所有 JS 知识点的集合 -- JS 知识体系框架.1-1 课程简介(导学)1-2 前言1-3 几个面试题1-4 如何搞定所有面试题 第2章 JS基础知识(上)讲解 JS 基础语法相关的面试题,分析原理以及解答方法.这一章节讲解了基础知识的第一部分:变量的类型和计算.以及JS "三座大山" -- 原型.作用域和异步中的第一座大山:原型.2-1 变量类型和计算-12-2 变量类型和计算-22-3

WEB前端学习笔记 二

1.4  JavaScript和Jquery能做什么? JavaScript是Netscape公司开发的一种基于对象和事件驱动的脚本语言 ,并且可在所有主要的浏览器中运行 IE.Firefox.Chorme.Opera ,JavaScript 可用来向 HTML 页面添加交互行为,如表单数据合法性验证.网页特效.动画效果.数值计算,例如你现在浏览的网知博学的首页面上的图片循环播放和导航分类,淘宝和京东的商品分类菜单等.JavaScript 是一种弱类型语言,无需编译,可由浏览器直接解释运行 特点

前端开发知识体系部

1. 前言 本文把整个web前端开发所需要的知识都之中在一个视图中,形成一个完整的web前端知识体系,目的是想要颠覆人们对于前端只有三大块(html.css.js)的认识--做web前端需要的比这三大块要多得多. 在看内容之前,先看一下这个知识框架的预览图.图太大不好展示,看不清除,可在此下载清晰版:http://pan.baidu.com/s/1hqIUvUc (内有整个知识体系的图片和xmind文件) 2. 分类 所有知识框架,那肯定是一个结构型的展现,就是一棵树.web前端的知识点非常多,

javascript生成二维码

摘要: 百度百科上是这样介绍二维码的:二维码(Quick Response Code),又称二维条码,它是用特定的几何图形按一定规律在平面(二维方向)上分布的黑白相间的图形,是所有信息数据的一把钥匙.在现代商业活动中,可实现的应用十分广泛,如:产品防伪/溯源.广告推送.网站链接.数据下载.商品交易.定位/导航.电子商务应用.车辆管理.信息传递等.如今智能手机扫一扫(简称313)功能的应用使得二维码更加普遍,随着国内物联网产业的蓬勃发展,更多的二维码技术应用解决方案被开发,二维码成为移动互联网入口

javaScript生成二维码(改造jquery.qrcode.js,使之支持中文,能带logo)

最近公司要求使用javaScript生成二维码,在网上搜了很多相关的资料,都不是很全面,俗话说:自己动手,丰衣足食. (这里吐槽下,有网友有了解决方案,却刻意把源代码压缩了,导致不知道改了什么东西,知识大家一起学习嘛,授人与鱼不如授人与渔!) 总结如下: 资料搜索 选择star最多的两个 第一个就是用的比较多的jquery.qrcode.js(但不支持中文,不能带logo)啦,第二个支持ie6+,支持中文,根据第二个源代码,使得,jquery.qrcode.js,支持中文. 支持中文 1 //q