1、JSON的遍历
 for(var i in json){
  alert(json[i];
 }
2、arguments 可以理解为是一个数组,并且建有json的部分能力
 css(obj,attr,value){
  obj.attr = value;
 }
3、字符串的单字符获取方法
 str.charAt(index); // 兼容全部浏览器
 str[index]; // 低版本浏览器不兼容
 
附记:
 1、获取元素在样式表中定义的属性值
     var getStyle = function(node, property){
   if (node.style[property]) {
    return node.style[property];
   }
   else if (node.currentStyle) {
    return node.currentStyle[property];
   }
    else if (document.defaultView && document.defaultView.getComputedStyle){
     var style = document.defaultView.getComputedStyle(node, null);
     return style.getPropertyValue(property);
    }
    return null;
  };
 2、常用JS工具
     var utils = {
   // 创建固定ID的标签
   createE:function(nodeName,id){var newEl = document.createElement(nodeName);if(id&&id!==""&&!document.getElementById(id)){newEl.id = id;}return newEl;},
   // 根据class Name获取元素集合
   getByC:function(className){return document.getElementsByClassName(className);},
   // 根据ID获取标签
   getById:function(id){return document.getElementById(id);},
   // 根据DOM对象和属性名获取属性值,解决获取样式时的兼容问题,
   // 兼容各种浏览器和行间样式与CSS样式
   getStyle:function(el,name){
    var stl = '';
    try{
     stl = el.style[name];
     if(stl==''){throw false;}
    }catch(e){
     try{
      stl = el.currentStyle[name];
     }catch(e1){
      try{
       stl = window.getComputedStyle(el,null)[name];
      }catch(e2){
      }
     }                   
    }finally{
     return stl;
    }
   },
   // 渐变效果,通常用于width\height\left\right\top\bottom等
    huadong:function(el,name,target,timer){var old=utils.getStyle(el,name);if(!el||!name||!target||!/^-?\d+/.test(target)||!/^-?\d+/.test(old)){return;}
                clearInterval(timer);var o=parseInt(old),t=parseInt(target),c=t-o,step=c>0?2:c<0?-2:0;timer=window.setInterval(function(){o+=step;utils.setStyle(el,name,o+'px');if((c>0&&o>=t)||(c<=0&&o<=t)){clearInterval(timer);}},10);},

};
 3、小工具:
  获取鼠标点击的“目标对象”:event.target, IE下为event.srcElement
   示例代码:
    <html>
     <head>
      <script type="text/javascript">
       function whichElement(e) // 获取鼠标点击对象的方法
       {
        var targ
        if (!e) var e = window.event // 如果e不存在
        if (e.target) targ = e.target // 事件目标节点(不兼容IE)
        else if (e.srcElement) targ = e.srcElement // IE下为event
        if (targ.nodeType == 3) // 当点击了文本节点Text
           targ = targ.parentNode // 文本节点的父节点
        var tname
        tname=targ.tagName // 元素类型
        alert("You clicked on a " + tname + " element.")
        /* 简写:
         e = e ? e : window.event;var targ = e.target ? e.target : e.srcElement ? e.srcElement : null;targ = targ.nodeType == 3 ? targ.parentNode:targ;
        */
       }
      </script>
     </head>
     <body onmousedown="whichElement(event)">
      <p>在文档中点击某个位置。消息框会提示出您所点击的标签的名称。</p>
      <h3>这是标题</h3>
      <p>这是段落。</p>
      <img src="/i/eg_mouse2.jpg" />
     </body>     
    </html>
 4、延伸扩展:如何判断当前浏览器是什么浏览器?
   简而言之,每个浏览器的独有属性的一个罗列:
   总所周知:当下比较常用的有Firefox(火狐浏览器)、Opera(欧鹏浏览器)、Safari(苹果公司的网络浏览器)、
    Chrome(谷歌浏览器);下面一一对各个浏览器相对独有的特性进行一个描述(暂时不谈论内核的差距,主要是从相关函数进行分析)。
   Firefox中的DOM元素都有一个getBoxObjectFor函数,用来获取该DOM元素的位置和大小
    IE对应的中是getBoundingClientRect函数)。这是Firefox独有的,判断它即可知道是当前浏览器是Firefox。
   Opera提供了专门的浏览器标志,就是window.opera属性。
   Safari浏览器中有一个其他浏览器没有的openDatabase函数,可做为判断Safari的标志。
   Chrome有一个MessageEvent函数,但Firefox也有。不过,好在Chrome并没有Firefox的getBoxObjectFor函数,
    根据这个条件还是可以准确判断出Chrome浏览器的。

javascript学习笔记_1的更多相关文章

  1. Java程序猿的JavaScript学习笔记(汇总文件夹)

    最终完结了,历时半个月. 内容包含: JavaScript面向对象特性分析,JavaScript高手必经之路. jQuery源代码级解析. jQuery EasyUI源代码级解析. Java程序猿的J ...

  2. Java程序猿的JavaScript学习笔记(8——jQuery选择器)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  3. Java程序猿JavaScript学习笔记(2——复制和继承财产)

    计划和完成在这个例子中,音符的以下序列: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaSc ...

  4. Java程序猿的JavaScript学习笔记(3——this/call/apply)

    计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript ...

  5. Java程序猿JavaScript学习笔记(4——关闭/getter/setter)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

  6. Java程序猿JavaScript学习笔记(14——扩大jQuery UI)

    计划和完成这个例子中,音符的顺序如下: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScr ...

  7. javascript学习笔记(四) Number 数字类型

    数字格式化方法toFixed().toExponential().toPrecision(),三个方法都四舍五入 toFixed() 方法指定小数位个数  toExponential() 方法 用科学 ...

  8. JavaScript学习笔记之数组(二)

    JavaScript学习笔记之数组(二) 1.['1','2','3'].map(parseInt) 输出什么,为什么? ['1','2','3'].map(parseInt)//[1,NaN,NaN ...

  9. JavaScript学习笔记[0]

    JavaScript学习笔记[0] 使用的是廖雪峰JavaScript教程. 数据类型 Number 表示数字,不区分浮点整形. === 比较时不转化数据类型. == 反之. NaN与任何值都不想等, ...

随机推荐

  1. 最简单获取appPackage和appActivity 的方法

    appPackage和appActivity 进行appium自动化测试必须的两个参数,我们所测试的APP项目不同,这两个参数肯定也是不一样的.我们启动的包都是靠这两个参数去驱动的,那么我们怎么可以快 ...

  2. 7、Dockerfile详解

    参考: https://www.imooc.com/article/details/id/25229 https://www.cnblogs.com/panwenbin-logs/p/8007348. ...

  3. unittest同时支持参数化和生成html报告

    最近在用python3.6+unittest+requests做自动化接口测试.发现一个问题,unittest中使用第3方插件parameterized进行参数化,再生成html报告时,运行就会失败. ...

  4. Linux——高效玩转命令行

    [0]统计文件or压缩文件的行数 zcat file.gz | sed -n '$='   #迅速.直接打印出多少行.-n 取消默认的输出,使用安静(silent)模式    '$='  不知道是什么 ...

  5. ASP.NET MVC CSRF (XSRF) security

    CSRF(Cross-site request forgery)跨站请求伪造,也被称为“One Click Attack”或者Session Riding,通常缩写为CSRF或者XSRF,是一种对网站 ...

  6. cowboy源码分析(三)

    上接 cowboy源码分析(二) 我们接着分析cowboy_protocol.erl的request/7模块 -module(cowboy_protocol). %% API.-export([sta ...

  7. 怎样使用md命令一次建立多级子目录

    https://jingyan.baidu.com/article/37bce2be30cae21002f3a224.html 点击开始,运行,在运行窗口中输入“cmd”.   打开cmd窗口之后,用 ...

  8. if-else语句

    C语言自学之if-else语句 Dome : 今年是2014年编写程序判断今年是闰年还是平年. 请在代码编辑器中使用简单if-else语句补全代码,判断今年是否是闰年. 运行结果: 今年是平年 #in ...

  9. ASCII与HEX对照转换表

    最近在研究ESC/POS 打印指令,时不时的就用到 ASCII和Hex的相互转换 ASCII HEX ASCII HEX ASCII HEX ASCII HEX NUL 00 DEL 10 Space ...

  10. ie11兼容

    项目里遇到ie11的问题, 1.控制台报:SCRIPT7002: XMLHttpRequest: 网络错误 0x80070005, 拒绝访问. 后来发现是由于传参过长,不应该用get请求,后改成pos ...