上篇介绍了15个常用代码段,本篇将把剩余的15个补齐,希望对大家有所帮助!!!


  16.检测Shift、Alt、Ctrl键:

  event.shiftKey;  //检测Shift

  event.altKey;   //检测Alt

  event.ctrlKey;  //检测Ctrl

  17.获取屏幕分辨率的宽、高:

  window.screen.height;  //获取屏幕的高

  window.screen.width;   //获取屏幕的宽

  18.脚本永不出错的方式:

  window.onerror=function(m,f,l){

    return true;

  };

  19.让 JavaScript 处理字符与 ASCII 码之间的转换:

  console.log("a".charCodeAt(0));       //97

  console.log(String.fromCharCode(75));  //K

  charCodeAt()返回指定位置字符的 Unicode 编码;fromCharCode()接收一个指定的 Unicode 值,然后返回一个字符串。

  20.访问对象属性:

  var demo = {name: 'ki'}

  demo.name;  //ki

  demo['name']; //ki

  访问对象属性一般通过两种方式,即“.”或“[ ]”。一般情况下两种方式等效,但是“[ ]”还可以动态设置属性,如:

  var get = 'name';

  demo [get];  //ki

  21.把一个值转换为布尔型:

  !!'demo';  //true

  !!'';      //false

  !!'0';      //true

  !!'1';     //true

  !!{};    //true

  !!true;    //true

  使用"!"操作符两次,可以把一个值转换为布尔型。

  22.判断浏览器是否支持 HTML 5:

  !!navigator.geolocation;

  23.判断浏览器是否支持 Canvas:

  function isCanvas( ) {

    return  !!document.createElement('canvas').getContext;

  }

  24.判断 IE 版本:

  window.navigator.appVersion;

  上述代码返回一个字符串,表示所使用浏览器的版本号。

  25.声明变量的缩略写法与复杂写法:

  /*复杂写法*/

  var x;

  var y;

  var z = 3;

  /*缩略写法*/

  var x, y, z = 3;

  26.采取惰性载入的方案提高函数代码的性能:

 1 function addEvents (type, element, fun) {
2
3     if (element.addEventListener) {
4
5     }
6
7     else if(element.attchEvent) {
8
9       element.attachEvent('on' + type, fun);
10
11     }
12
13     else {
14
15       element['on' + type] = fun;
16
17     }
18
19   }

  所谓惰性载入就是在第一次执行代码后,用函数代码内部的方法覆盖原有代码,即:

 var addEvents = (function () {
if(document.addEventListener) {
return function (type, element, fun) {
element.addEventListener(type, fun, false);
}
}
else if(document.attachEvent) {
return function (type, element, fun) {
element.attachEvent('on' + type, fun);
}
}
else {
return function (type, element, fun) {
element['on' + type] = fun;
}
}
})();

  27.捕捉 Ctrl+Enter 按键:

  if(event.ctrlKey && event.keyCode == 13)

  {

    console.log("You pressed the Ctrl + Enter");

  }

  28.获取浏览器的插件数目:

  navigator.plugins.length;

  29.实现对 Windows、Mac、Linux、UNIX 操作系统的判断:

 var osType = "",
windows = (navigator.userAgent.indexOf("Windows",0) != -1)?1:0;
mac = (navigator.userAgent.toLowerCase().indexOf("mac",0) != -1)?1:0;
linux = (navigator.userAgent.indexOf(”Linux",0) != -1)?1:0;
unix = (navigator.userAgent.indexOf("X11",0) != -1)?1:0; if(windows) osType = "Windows";
else if(mac) osType = "Mac";
else if(linux) osType = "Linux";
else if(unix) osType = "Unix";
console.log(osType);

  30.使用原生 JavaScript 判断是否是移动设备浏览器:

 var mobileReg = /iphone | ipod | androdid.*mobile | windows.*phone | blackberry.*mobile/i;

   if((mobileReg.test(window.navigator.userAgent.toLowerCase()))){

     alert("移动设备! ");

   }else{

     alert("非移动设备! ");

   }

  至此,30段 JavaScript 代码分享结束,本系列的下一篇将介绍一些学习 JavaScript 必须知道的事儿,敬请关注!

JavaScript代码段整理笔记系列(二)的更多相关文章

  1. JavaScript代码段整理笔记系列(一)

    30段JavaScript代码——上篇 1.如何区分IE及非IE浏览器: if(!+[1,]){ //IE 11 不支持 alert("这是 IE 浏览器"): }else{ al ...

  2. 前端福利!10个短小却超实用的JavaScript 代码段

    JavaScript正变得越来越流行,它已经成为前端开发的第一选择,并且利用基于JavaScript语言的NodeJS,我们也可以开发出高 性能的后端服务,甚至我还看到在硬件编程领域也出现了JavaS ...

  3. C# 代码中调用 Javascript 代码段以提高应用程序的配置灵活性(使用 Javascript .NET 与 Jint)

    一般来说,我们需要在开发应用软件的配置文件中,添加一些参数,用于后续用户根据实际情况,自行调整. 配置参数,可以放在配置文件中.环境变量中.或数据库表中(如果使用了数据库的话).通常,配置数据,以 k ...

  4. 推荐10 个短小却超实用的 JavaScript 代码段

    1. 判断日期是否有效 JavaScript中自带的日期函数还是太过简单,很难满足真实项目中对不同日期格式进行解析和判断的需要.jQuery也有一些第三方库来使日期相关的处理变得简单,但有时你可能只需 ...

  5. 数据段描述符和代码段描述符(二)——《x86汇编语言:从实模式到保护模式》读书笔记11

    这篇博文,我们编写一个C语言的小程序,来解析数据段或者代码段描述符的各个字段.这样我们阅读原书的代码就会方便一点,只要运行这个小程序,就可以明白程序中定义的数据段或者代码段的描述符了. 这段代码,我用 ...

  6. canvas学习之API整理笔记(二)

    前面我整理过一篇文章canvas学习之API整理笔记(一),从这篇文章我们已经可以基本了解到常用绘图的API.简单的变换和动画.而本篇文章的主要内容包括高级动画.像素操作.性能优化等知识点,讲解每个知 ...

  7. 《超实用的JavaScript代码段》—— 读后总结

    这本书全是代码,从头到尾跟着坐下来确实收获很多.比那些古板的教科书式的理解更多,不过书中并不是每个例子都做了,有的作者封装的太多,觉得看了收获不多,就没细看——比如模块渐变.有空好好学学这段的代码. ...

  8. chrome小书签-实用的小功能-javascript代码段

    1.打印页面的所有脚本引用文件及代码段: javascript:var scriptarray=document.getElementsByTagName("script");fo ...

  9. 《JavaScript实用效果整理》系列分享专栏

    整理一些使用的JavaScript效果,在Web开发中遇到的比较好的动态效果,都收藏在这里,对以后的网站开发增加不少的色彩 <JavaScript实用效果整理>已整理成PDF文档,点击可直 ...

随机推荐

  1. .NET中的逆变协变

    MSDN上的说法: 协变和逆变都是术语,前者指能够使用比原始指定的派生类型的派生程度更小(不太具体的)的类型,后者指能够使用比原始指定的派生类型的派生程度更大(更具体的)的类型----------(注 ...

  2. Python(六)面向对象、异常处理、反射、单例模式

    本章内容: 创建类和对象 面向对象三大特性(封装.继承.多态) 类的成员(字段.方法.属性) 类成员的修饰符(公有.私有) 类的特殊成员 isinstance(obj, cls) & issu ...

  3. 代码的坏味道(9)——异曲同工的类(Alternative Classes with Different Interfaces)

    坏味道--异曲同工的类(Alternative Classes with Different Interfaces) 特征 两个类中有着不同的函数,却在做着同一件事. 问题原因 这种情况往往是因为:创 ...

  4. 基于HTML5的WebGL应用内存泄露分析

    上篇(http://www.hightopo.com/blog/194.html)我们通过定制了CPU和内存展示界面,体验了HT for Web通过定义矢量实现图形绘制与业务数据的代码解耦及绑定联动, ...

  5. FastSocket学习笔记~再说客户端与服务端的组成

    废话多说 很久之前,我写过几篇FastSocket的文章,基本属于使用的方法,而缺乏对概念的总结讲解,而本讲就是弥补一下上几讲的不足,将核心的模块再说说,再谈谈,再聊聊! 首先FastSocket由C ...

  6. php函数获取真实客户端IP地址

    function getIPaddress(){ $IPaddress=''; if (isset($_SERVER)){ if (isset($_SERVER["HTTP_X_FORWAR ...

  7. linux(十二)___Apache服务器用户认证、虚拟主机的配置

    创建xiangkejin  zhangsan两个用户 可看见文件中创建的两个用户: 建立虚拟目录并配置用户认证 ①建立虚拟目录 /xiangkejin ②在Apache的主配置文件httpd.conf ...

  8. 学习廖雪峰的git教程

    地址:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 1.git add:添加文件 ...

  9. Canvas的width,height 和 样式中Canvas的width,height

    控制Canvas的大小,有两种方式: 1:直接设置Canvas标签上的书width,height属性值; 2:通过Css设置Canvas的width,height; 这两种方式,区别是很大的. 1:C ...

  10. 【shadow dom入UI】web components思想如何应用于实际项目

    回顾 经过昨天的优化处理([前端优化之拆分CSS]前端三剑客的分分合合),我们在UI一块做了几个关键动作: ① CSS入UI ② CSS作为组件的一个节点而存在,并且会被“格式化”,即选择器带id前缀 ...