一些实用的js高级技巧

技巧一之setTimeout.

应用案例:比如你想一个函数循环执行10次,怎么办?以前通常是先setInterval,然后clearInterval,技巧一就是克服这个问题

(function () {
var i = 0;
function job() {
console.log(i++);
if (i < 10) {
setTimeout(job, 1000);
}
}
job();
})();

  

上面这个job函数就只会乖乖的执行10次.然后自动停止 
技巧二之高效的for循环 
应用案例:抛弃传统的循环方式

(function () {
var arr=[];
for(var i=arr.length;i--;){
doStuff();
}
})();

  

这个方式为什么高效? 
一:少了一个参数l=arr.length; 
二:for语句中间那个玩意少进行了一次计算,以前的话是for(i=0;i<l;i++)这样的话中间的语句会先比较i<l 然后比较出来的结果在 
跟true 或者false比较,自然多了次计算 
技巧三之高效赋值 
应用案例:抛弃传统的if判断赋值

var i=1,ret;
ret=i!==1||true;
console.log(ret);

  

以上代码会很神奇的告诉你ret会是true.高效吧不用if(i!==1)了在赋值了 
技巧四之强悍的简短的attr 
应用案例:setAttribute,getAttribute.这个方法不仅可以设置标准的属性,还可以设置任意属性,兼容好

function attr(elem, name, value) {
var ret;
if (value) {
if (/msie [6-7]\.0/i.test(navigator.userAgent)) {
ret = elem.getAttributeNode(name);
if (!ret) { //ie6 7不合法的属性设置捕鸟,通过这里可以设置
ret = document.createAttribute(name);
elem.setAttributeNode(ret);
}
ret.nodeValue = value + "";
} else {
elem.setAttribute(name, value);
}
return elem;
} else { //ie6 7有得属性获取不鸟
ret = elem.getAttribute(name);
fixIe = elem.getAttributeNode(name).nodeValue;
ret = ret ? ret : fixIe ? fixIe : undefined;
return ret;
}
}

  

以上方法如何测试呢? 
attr(document.getElementById("test"), "classxx", "xx") 
alert(attr(document.getElementById("test"),"classxx")); 
技巧五之getElementsByClassName. 
应用案例 :

(function () {
var getElementsByClassName=function(cls,context){
var root = context || document;
return document.querySelectorAll ? root.querySelectorAll("." + cls) : root.getElementsByClassName ?
root.getElementsByClassName(cls) : help("*", cls, context);
}
var help=function(tagName,cls,context){
var root= context || document,
ret=[],elems,i,
rcls=new RegExp("^|\\s+"+cls+"\\s+|$");
elems = root.getElementsByTagName(tagName || "*");
for(i=elems.length;i--;){
if(rcls.test(elem[i].className)){
ret.push(elems[i]);
}
}
return ret;
}
})();

  

时间: 2024-08-30 05:07:00

一些实用的js高级技巧的相关文章

js 高级技巧

1.高级函数 1.1 安全的类型检测 typeof  操作符,对一个值使用可能返回下列某个字符串 undefined, boolean, string, number, object, function null 也返回 object instanceof  用来判断对象是否为某个类的实例 var isArray = value instanceof Array Object.prototype.tostring.call(value);         // 安全的类型检测 1.2 惰性载入

简单但很实用的js手风琴效果

<!DOCTYPE html> <html> <head>     <meta charset="UTF-8">     <title></title>     <style> body,ul,li,.sfq,h3{     margin: 0;     padding: 0;     list-style: none; }   h3{       height: 30px;       width: 

实用的JS代码段(表单篇)

整理了下比较实用的Javascript代码段,完整的代码参考 1 多个window.onload方法 由于onload方法时在页面加载完成后,自动调用的.因此被广泛的使用,但是弊端是只能实用onload执行一个方法.下面代码段,可以保证多个方法在Onload时执行: function addLoadEvent(func){ var oldonload = window.onload; if(typeof window.onload != 'function'){ window.onload =

js高级技巧---拖放

拖放:点击某个对象,并按住鼠标按钮不放,将鼠标移动到另一个区域,然后释放鼠标按钮将对象“放”在某处. 涉及到event的对象的属性: clientX,clientY:当事件被触发时鼠标指针相对于浏览器页面(或客户区)的坐标. screenX,screenY:当事件发生时鼠标指针相对于屏幕的坐标. offsetX,offsetY:当事件发生时鼠标指针相对于触发事件的元素内边界的坐标. x,y:当事件发生时鼠标指针相对于触发事件的元素外边界的坐标. 1.声明了一个对象DragDrop,该对象是一个单

js高级技巧----自定义事件

自定义事件 原本的事件处理的原理:事件是javascript与浏览器交互的主要途径. 事件是一种叫做观察者的设计模式 观察者模式由两类对象组成:主体和观察者. 主体用于发布事件: 观察者通过订阅这些事件来观察该主体. 自定义事件的原理: 将事件处理程序保存在一个数组中: 当添加事件的时候,我们push进去这个事件处理函数: 当我们执行的时候,从头遍历这个数组中的每个事件处理函数,并执行. 自定义事件应该具有的内容: 1.一个handler对象,对象中保存着存放事件处理函数的数组 handler 

灵活实用require.js,让JS加载速度更流畅

当一个网页引入很多js文件,网页加载会变得很慢,并且js文件存在依赖性,有时候颠倒顺序就不能运行了,这很影响用户体验. require.js解决了异步加载,提高网页的加载,同时依赖顺序的js可以用数组排序. 第一部加载require.js放到目录的js子目录下: <script src="js/require.js"></script> 需要加一个参数 defer async="true" 表示这个文件需要异步加载 defer兼容IE版本 需

js高级技巧之高级定时器

实际上,浏览器负责进行排序,指派某段代码在某个时间点运行的优先级. 可以吧js想象成在时间线上运行的. JavaScript中没有任何代码是立刻执行的,但一旦进程空闲则尽快执行. 1.重复的定时器: setInterval()的重复定时器存在两个缺点: (1)某些间隔会被跳过 (2)多个定时器的代码执行之间的间隔可能比预期的小: 假设,某个onclick事件处理程序使用setInterval()设置了一个200ms间隔的重复定时器.如果事件处理程序花了300ms多一点的时间完成,同时定时器代码也

很实用的js限制不让输入其他字符,只让输入数字和 js生成UUID

onkeyup="this.value=this.value.replace(/\D/g,'')" js生产UUID 1 var createUUID = (function (uuidRegEx, uuidReplacer) { 2 return function () { 3 return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(uuidRegEx, uuidReplacer).toUpperCase();

JS高级技巧学习小结

安全类型检测 <script type="text/javascript"> //判断某个值是不是原生数组 function isArray(value){ return Object.prototype.toString.call(value)=="[object Array]"; } //判断某个值是不是原生函数 function isFunction(value){ return return Object.prototype.toString.c