zoukankan      html  css  js  c++  java
  • [读书笔记]高性能JS-编程实践

    This part is some example to practice.

    1 avoid double evaluation

    less use of eval,new Function,settimeout,setinterval.

    string in these method are executable js code.when use these method,js will execute code twice ,first is normal js,second is js code in string ,such as var a=eval('1+2');first Asignment,second run code in string '1+2';

    in normal,don't use new Function. try to use function instead of string both in serttimeout and setinterval;

    2 use literal;

    var obj={

      'a':1,

      "b":2

    }

    var arr=[1,2,3,4]

    these two are good and run fast than something as 

    var obj={};

    obj.a=1;

    obj.b=2;

    3 no repeated job

    normally, we addevent use the function as

    function addEvent(obj,type,handler){
        if(obj.addEventListener){
            obj.addEventListener(type,handler,false)
        }else{
            obj.attachEvent('on'+type,handler);
        }
    }
    function removeEvent(obj,type,handler){
        if(obj.removeEventListener){
            obj.removeEventListener(type,handler,false)
        }else{
            obj.detachEvent('on'+type,handler);
        }
    }
    when called ,function will do repeated job for check which browser we using. actually ,one test is enough.

    one way to avoid is lazy load.

    function addEvent(obj,type,handler){
    if(obj.addEventListener){
    addEvent= function (obj,type,handler) {
    obj.addEventListener(type,handler,false)
    }
    }else{
    addEvent= function (obj,type,handler) {
    obj.attachEvent('on'+type,handler);
    }
    }
    addEvent(obj,type,handler)
    }

    call this method once,and new addEvent will override the past one.so next time called,it save lots of time.

    and another way is conditional load.

    var addevent=document.body.addEventListener?
    function (obj,type,handler) {
    obj.addEventListener(type,handler,false)
    }: function (obj,type,handler){
    obj.attachEvent('on'+type,handler);
    }
    cool way.






  • 相关阅读:
    ASP.NET MVC中权限控制的简单实现
    HDU1004——Let the Balloon Rise
    如何使用飞秋FeiQ实现两电脑通信(或传输文件)
    vb.net 鼠标控制
    ireport制作报表pageheader只在第一页出现的解决办法
    Keycode对照表
    leetcode第一刷_Binary Tree Zigzag Level Order Traversal
    换硬币问题
    STM32 寄存器库和固件库
    java网络编程(2)InetAddress 类及udp协议
  • 原文地址:https://www.cnblogs.com/wz0107/p/4957416.html
Copyright © 2011-2022 走看看