javascript常用积累

本文总结了一系列前端JavaScript实用技巧,包括解决动画与动作不一致的问题、阻止事件冒泡、查看对象属性、页面刷新时禁用提交按钮、获取事件及键盘码、鼠标滑动样式切换等,并介绍了如何在IE10下自定义渲染方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、JS动画与动作不一致解决:

1
2
3
if(!$( "#handle").is(":animated")){
//判断元素是否处于动画状态
}
二、停止事件冒泡

1
2
3
4
5
6
7
8
9
10
11
event.stopPropagation();
- 禁止JS报错
window.onerror = function(){
return true ;
}
 
try {
/*try to do*/
} catch(e){
/*do this if try error */
}
三、查看JS对象属性

1
2
3
4
5
6
7
var res = '' ;
var obj = eval( obj );
for( var p in eval( obj ) ){
var prop = p + ':' + obj[p] + '\n' ;
res += prop ;
}
alert( res );
四、页面刷新时禁用提交按钮

1
2
3
window.onbeforeunload = function(){
$(':submit').attr('disabled',true);
}

注意Opera 浏览器不支持,其他浏览器避免在同一页面中使用 "javascrpt:" 等伪协议

五、获取事件

1
2
3
4
5
6
7
8
9
var getEvent = function(){
var ieEvent = window.event ;
var ffEvent = arguments.callee.caller.arguments[0] ;
//arguments.callee 当前执行函数
//arguments.callee.caller 当前执行函数的调用者
//arguments.callee.caller.arguments[0] 当前函数调用者的第一个参数
var e = ieEvent || ffEvent ;
return e ;
}
六、获取键盘码

1
2
3
4
5
6
7
var getKCode = function(){
var ieEvent = window.event ;
var ffEvent = arguments.callee.caller.arguments[0] ;
var e = ieEvent || ffEvent ;
var kCode = e.keyCode || e.which ;
return kCode ;
}
七、 鼠标滑入/滑出样式切换

1
2
3
$("div").on("mouseover mouseout", function(){
$(this).toggleClass("over");
});
八、点击鼠标,显示/隐藏切换

1
2
3
4
5
6
7
$("#panel h5.head").toggle(function(){
$(this).toggleClass("highlight");
$(this).next().toggle();
},function(){
$(this).toggleClass("highlight");
$(this).next().toggle();
});
九、JS 调试

1
2
3
4
5
console.log() ; //打印变量
console.dir() ; //打印对象
console.dirxml() ; //打印节点
console.trace() ; //打印函数调用轨迹
window.document.title = str;
十、为子元素集合绑定事件

1
2
3
$("div").delegate("button","click",function(){
$("p").slideToggle();
});
十一、自定义IE浏览器渲染方式(解决IE10JS或插件失效):

如果安装了Chrome内核,则使用Chrome内核来渲染页面[chrome=1],如果未安装,则使用最高版本的IE内核进行渲染[IE=edge]:

1
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
十二、注册事件

1
2
3
4
5
// 标准浏览器
form1.addEventListener('submit', function(e){
e.preventDefault(); //阻止浏览器默认动作
e.stopPropagation(); //阻止事件流产生
});
1
2
3
4
5
// IE8及更早版本IE浏览器
form1.attachEvent('submit', function(){
event.cancelBubble = true; //阻止浏览器默认动作--IE8及更早版本IE浏览器
event.returnValue = false; //阻止事件流产生--IE8及更早版本IE浏览器
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值