30段有用的javascript代码
1. 如何区分IE及非IE浏览器
if(!+[1,]){
console.log("这是IE浏览器");
} else{
console.log("这不是IE浏览器");
}
<script type="text/javascript">
alert([1,2]);//相当于alert([1,2].toString()); --这在IE与非IE上都相同,都会弹出"1,2"
alert([1,]);//相当于alert([1,].toString());--在非IE的标准浏览器上,js引擎会自动删除最后的",",所以在IE上会弹出"1,",而在非IE上会弹出"1"
alert(+[1,]);//根据上面的解释,这一句在IE上相当于alert(+"1,"),而在非IE上相当于alert(+"1"),正号的作用在于试图将字符串转换为数字,"1,"当然不是数字,而"1"可以转换为数字1,所以最终的结果:IE上会转换失败弹出"NaN",而非IE浏览器上会弹出数字"1" //上面的+号转换字符串为数字的测试
var s = +"5";
alert(s+1); //ok,到这里为止,我们知道 +[1,] 最终在IE为上NaN,在非IE浏览器上则为数字1 //下面再来看看很有个性的NaN
alert(NaN==true);//弹出 false
alert(NaN==false);//弹出 false
alert(NaN==NaN);//弹出 false //即NaN不管与谁比较都是false
alert(!NaN);//相当于alert(!(NaN==true)),根据上面的解释当然是弹出true //所以,alert(!+[1,]) 最终在IE上会弹出"true",下面再来看看firefox等非IE浏览器上的表现
alert(new Boolean(0));//false
alert(new Boolean(1));//true
alert(new Boolean(-1));//true
//即:数字0会转换为false,其它任何数字都会转换为true,所以最终在非IE浏览器上最终等效于:
alert(!1);
//即
alert(!true)//最终会得到false //综上所述:下面的这个判断就能判定浏览器是不是IE
if (!+[1,]){
alert("我是货真价实的IE浏览器!")
}
else{
alert("我不是IE!")
}
</script>
这个在IE6、7、8里运行是对的,但是在9、10、11里已经修复了,和其他modern浏览器显示效果是一样的,所以,这个使用时要做区分!
2. 将日期直接转换成数值
+new Date();
3. 非IE浏览器下将类数组对象'arguments'专为数组 Array.ptrototype.slice.call(arguments); arguments不是Array的实例,因此不是真正的数组,也就没有slice()方法,但为什么用"Array.prototype.slice"而不是"Array().slice"或"[].slice()"呢?因为这两种方法效率比较低,故使用代码中的写法访问Array的内置函数。
4. 最简单的运算符 var a = 0 || 3;
console.log(a); //结果3 如果=后面的第一个值计算结果为布尔值“真”,则a的值取第1个,否则取第2个。
5.单链式计算 var a = 10;
console.log(a++ -1); 先执行"a-1", 在执行"a = a+1"。
6. 有趣的void操作符 <a href="javascript:void(0)">我是个死链接</a> void是一种操作符,用来计算一个表达式但不返回值。用法: javascript:void(expression),expression是一个要计算的javascript标准表达式。
. 跳转至新页面,并且保证浏览器不会再回退
location.replace("url"); location的replace()方法可以用一个新的文档替换当前文档,并且该方法还会覆盖History对象中的记录。
8.几秒钟之后返回上一页
<meta htt-equiv="refresh" content="3, url=javascript:window.hostory.go(-1);"> 其中content为设置的时间
.在打开的子窗口中刷新父窗口
window.opener.location.reload();
10. 验证是否为负数的正则表达式
/^-\d+$/.test(str);
. 用javascript打印网页
window.print(); window.print()属于浏览器内置的API,可以直接打印页面
12. 显示/隐藏一个DOM元素
el.style.display = "";
el.style.display = "none"; DOM元素的显示/隐藏主要通过设置元素的样式display属性来实现。
. 实现alert()中的文本换行
alert("p\np"); "\n"代表换行符。
14. 实现ECMAScript5中的Object.create()函数
function clone(proto){
function _clone() {}
_clone.prototype =proto;
_clone.prototype.constructor = _clone;
return new _clone; //等价于Object.create(Person)
}
var me = clone(Person); 用原型链形式继承,构造函数重新指向新创建的对象。
15. 理解javascript中的闭包
//例如,以下代码会输出5次,结果都是5,如何输出1、2、3、4?
for(var i=0; i<5;i++) {
setTimeout(function(){
console.log(i);
},1000);
} //5次结果都是5
//利用闭包原理实现, 代码如下
for(var i=0; i<5;i++) {
(function(e) {
setTimeout(function(){
console.log(e);
},1000);
})(i)
} //5次结果都是0,1,2,3,4
16. 检测Shift、Alt、Ctrl键
//以下是浏览器内置的检测方法
event.shiftKey; //检测Shift
event.altKey; //检测Alt
event.ctrlKey; //检测Ctrl
.获取屏幕分辨率的宽、高
window.screen.height; //获取屏幕高度
window.screen.width; //获取屏幕宽度 window.screen这个对象包含了有关用户屏幕的信息
.脚本永不出错的方法
window.onerror = function(m, f, l){
return true;
};
.让javascript处理字符与ASCLL码之间的转换
console.log("a".charCodeAt(0)); //
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. 判断浏览器是否支持HTML5
!!navigator.geolocation; 在HTML5中,navigator.geolocation可以获取设备的当前位置,通过"!"就可以判断是否支持此API,即是否支持HTML5。
23. 判断是否支持Canvas
function isCanvas() {
return !!document.createElement('canvas').getContext;
}
.判断IE版本
window.navgator.appVersion 上述代码返回一个字符串, 表示所使用浏览器的版本号。他可能只包含一个数字,比如5.0,还可能包含一些其它信息。
25. 声明变量的缩略写法与复杂写法
/*复杂写法*/
var x;
var y;
var z=3; /*缩略写法*/
var x, y, z=3; javascript是比较灵活的语言,编程时尽量使用缩略写法,这样会提高javascript性能。
26. 采取惰性载入的方案提高函数代码的性能
function addEvents(type, element, fun) {
if(element.addEventListener) {
element.addEventListener(type, fun, false);
}
else if(element.attachEvent) {
element.attachEvent('on' + type, fun);
}
else{
element['on'+tyoe] =fun;
}
} //所谓惰性载入就是在第一次执行代码后,用函数代码内部的方法覆盖原有代码,代码如下:
var addEvents = (function() {
if(element.addEventListener) {
element.addEventListener(type, fun, false);
}
else if(element.attachEvent) {
element.attachEvent('on' + type, fun);
}
else{
element['on'+tyoe] =fun;
}
})();
27. 捕捉Ctrl+Enter按键
if(event.ctrlKey && event,keyCode == 13) {
console.log("you pressed the Ctrl+Enter")
} enter.ctrlKey检测Ctrl键,event.keyCode == 13检测Enter键。
. 获取浏览器插件的数目
navigator.plugins.length; 用navigator用来检测浏览器的版本、所支持的MIME类型,已安装的外挂程序(plugin)。
29. 实现对Window、 Mac、 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); navigator.userAgent表示用户代理。
30. 使用原生javascript判断是否是移动设备浏览器
var MobileReg =/iphone|ipod|android.*mobile|windows.*phone|blackberry.*mobile/i ;
if(mobileReg.test(window.navigator.userAgent.toLowerCase())) {
alert("移动设备!");
}else {
alert("非移动设备!");
}
30段有用的javascript代码的更多相关文章
- 一段有用的javascript加密解密
今天在做一个老项目时,遇到一个需求,在javascript将url中的参数加密解密,从网上找发现了这段有用的代码: <SCRIPT LANGUAGE="JavaScript" ...
- 30段极简Python代码:这些小技巧你都Get了么
学 Python 怎样才最快,当然是实战各种小项目,只有自己去想与写,才记得住规则.本文是 30 个极简任务,初学者可以尝试着自己实现:本文同样也是 30 段代码,Python 开发者也可以看看是不是 ...
- 30段极简Python代码
Python 是机器学习最广泛采用的编程语言,它最重要的优势在于编程的易用性.如果读者对基本的 Python 语法已经有一些了解,那么这篇文章可能会给你一些启发.作者简单概览了 30 段代码,它们都是 ...
- 网页上记录鼠标的点击次数和一段有用的php代码,自己学习使用
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 精心收集的 48 个 JavaScript 代码片段,仅需 30 秒就可理解!
原文:https://github.com/Chalarangelo/30-seconds-of-code#anagrams-of-string-with-duplicates 作者:Chalaran ...
- 精心收集的 48 个 JavaScript 代码片段,仅需 30 秒就可理解
原文:Chalarangelo 译文:IT168 https://github.com/Chalarangelo/30-seconds-of-code#anagrams-of-string-with ...
- 精心收集的48个JavaScript代码片段,仅需30秒就可理解
源文链接 :https://github.com/Chalarangelo/30-seconds-of-code#anagrams-of-string-with-duplicates 该项目来自于 G ...
- 一段奇葩Javascript代码引发的思考
今天与一挚友加同事调试一段奇葩的javascript代码,在分析出结果后,让我萌生了写此篇文章的想法,如有不对之处望指正,也欢迎大家一起讨论.缩减后的js代码如下,你是否能准确说明他的输出值呢? fu ...
- 30 段 JavaScript 代码
1. 前端人员经常遇到的问题就是如何区分IE及非IE浏览器,JavaScript代码是: if(!+[1,]) { //IE11不支持 alert('这是IE浏览器'); }else{ alert(' ...
随机推荐
- Java Collection.RP
在 Java2中,有一套设计优良的接口和类组成了Java集合框架Collection,使程序员操作成批的数据或对象元素极为方便.这些接口和类有很多对抽象数据类型操作的API,而这是我们常用的且在数据结 ...
- Java Calendar 类的时间操作.RP
JavaCalendar 类时间操作,这也许是创建和管理日历最简单的一个方案,示范代码很简单. 演示了获取时间,日期时间的累加和累减,以及比较. 原文地址:blog.csdn.NET/joyous/a ...
- rf常用关键字
上传文件choose file 用法:choose file 元素定位 文件路径\\文件名 此处注意:复制的路径是/,需全部替换成\\ 清除Clear Element Tex ...
- 基于.NET平台常用的框架整理[转载]
自从学习.NET以来,优雅的编程风格,极度简单的可扩展性,足够强大开发工具,极小的学习曲线,让我对这个平台产生了浓厚的兴趣,在工作和学习中也积累了一些开源的组件,就目前想到的先整理于此,如果再想到,就 ...
- [C# 线程处理系列]专题四:线程同步
目录: 一.线程同步概述 二.线程同步的使用 三 .总结 一.线程同步概述 前面的文章都是讲创建多线程来实现让我们能够更好的响应应用程序,然而当我们创建了多个线程时,就存在多个线程同时访问一个共享的资 ...
- MongoDB 分片2
mongodb 在windows下面进行分片 mongodb 更新很快,在做分片的时候,查找了不少文章,但是很多已经过时了.现在把我搭建的过程及命令分享给大家.我用的是最新版本windows版3.4. ...
- UWP_开源小程序 水印添加器
前几天写了一个确定水印位置的小博客.决定要写一个添加水印的UWP程序. 目前程序技术方面已经差不多了.所以提上日程
- thinkphp 连接数据库 & 实例化模型操作 (下接thinkphp CURD 操作)/慕课
7.1 连接数据库 (06:15) 1 7.2实例化模型 1 1.实例化基础模型 2 2. 实例化用户自定义模型 2 问题 2 3. 实例化公共模型 4 4. 实例化空模型 7 7.1 连接数据 ...
- SpringBoot浏览器直接访问html
在resources文件夹或与其并列的文件夹下建立public文件夹,在public文件夹下的html文件可以通过浏览器中输入文件+后缀名的方式直接访问的. 一.public文件夹,就相当于在ecl ...
- shared_ptr 和auto_ptr智能指针
shared_ptr:计数的智能指针 它是一个包装了new操作符在堆上分配的动态对象,但它实现的是引用计数型的智能指针 ,可以被自由地拷贝和赋值,在任意的地方共享它,当没有代码使用(引用计数为0)它时 ...