Javascript小技能总结(推荐)


Posted in Javascript onJune 02, 2016

废话不多说,直接上干货。。

具体代码如下所示:

/*
@@截取字符串长度,汉字算2个字符
@@return [string]+'...'
*/
var subString = function(str, len) {
var newLength = 0;
var newStr = "";
var chineseRegex = /[^\x00-\xff]/g;
var singleChar = "";
var strLength = str.replace(chineseRegex, "**").length;
for (var i = 0; i < strLength; i++) {
singleChar = str.charAt(i).toString();
if (singleChar.match(chineseRegex) != null) {
newLength += 2;
} else {
newLength++;
}
if (newLength > len) {
break;
}
newStr += singleChar;
}
if (strLength > len) {
newStr += "...";
}
return newStr;
}
--------------------------------------------------------------------------------
/*
@@对可见元素 进行隐藏
@@:visible 判断是否为课件元素
*/
function close_window(){
var flag=false;
$(".dialog_con").each(function(){
if($(this).is(":visible")){
flag=true;
}
})
if(flag==true){
$(".dialog_con").hide();
$(".dialogbox").hide(); 
}else{ 
window.android.callAndroidFinish();
}
} 
--------------------------------------------------------------------------------
/*
@@对持有不同设备的 设备 引用不同的样式
@@ if判断是否 某种设备
*/
<script type = "text/javascript" >
if (/(iPad|iPod|iOS)/i.test(navigator.userAgent)) { 
setActiveStyleSheet("pad.css"); 
} else if (/(Android)/i.test(navigator.userAgent)) {
setActiveStyleSheet("common.css"); 
}else if (/(iPhone6)/i.test(navigator.userAgent)) {
setActiveStyleSheet("iphone6.css"); 
}
function setActiveStyleSheet(filename){
document.write("<link href="+filename+" rel=stylesheet>");
}
</script>
--------------------------------------------------------------------------------
/*
@@回到顶部动画
@@
*/
$('a.top').click(function (e) {
e.preventDefault();
$(document.body).animate({scrollTop: 0}, 800);
});
--------------------------------------------------------------------------------
/*
@@检查图片是否加载完毕
@@有时你或许要检查图片是否完全加载完毕,才能在脚本中进行后续操作:
@@你也可以通过把 img 标签替换成 ID 或 class,来检查特定图片是否加载完成。
*/
$('img').load(function () {
console.log('image load successful');
});
--------------------------------------------------------------------------------
/*
@@动修复损坏的图片
@@如果你发现自己网站的图片链接挂了,一个一个替换很麻烦。这段简单的代码可以帮上大忙;
@@即使你没有任何损坏的链接,增加这段代码也不会有什么影响。
*/
$('img').on('error', function () {
$(this).prop('src', 'img/broken.png');
});
--------------------------------------------------------------------------------
/*
@@Hover 上的 Class 切换
@@如果用户的鼠标悬停在页面上某个可点击元素时,你想要改变这个元素的视觉表现。可以使用下面这段代码,当用户悬停时,为该元素增加一个 class;当用户鼠标离开后移除这个 class:
*/
$('.btn').hover(function () {
$(this).addClass('hover');
}, function () {
$(this).removeClass('hover');
});
-----------或---------
$('.btn').hover(function () {
$(this).toggleClass('hover');
});
--------------------------------------------------------------------------------
/*
@@禁用 input 字段
@@有时你也许想让表单的提交按钮或其文本输入框变得不可用,直到用户执行了一个特定行为(例如确认 “我已经阅读该条款” 的复选框)。增加 disabled attribute 到你的 input,就可以实现自己想要的效果
*/
$('input[type="submit"]').prop('disabled', true);
$('input[type="submit"]').prop('disabled', false);
--------------------------------------------------------------------------------
/*
@@停止链接加载
@@有时你不想链接跳转到某个页面或重加载该页面,而希望可以做一些其他事情,比如触发其他脚本。下面的代码是禁止默认行为的一个小诀窍
*/
$('a.no-link').click(function (e) {
e.preventDefault();
});
--------------------------------------------------------------------------------
/*
@@淡入淡出/滑动开关
@@淡入淡出与滑动是我们经常使用 jQuery 做成的动画效果。或许你只是想在用户点击某物时展现一个元素,使用 fadeIn 和 slideDown 都很棒。但如果想让该元素在第一次点击时显现,第二次点击时消失,下面的代码可以很好地完成
*/
// Fade
$('.btn').click(function () {
$('.element').fadeToggle('slow');
});
// Toggle
$('.btn').click(function () {
$('.element').slideToggle('slow');
});
--------------------------------------------------------------------------------
/*
@@简单的手风琴效果
@@这是一个快速实现手风琴效果的简单方法
*/
// Close all panels
$('#accordion').find('.content').hide();
// Accordion
$('#accordion').find('.accordion-header').click(function () {
var next = $(this).next();
next.slideToggle('fast');
$('.content').not(next).slideUp('fast');
return false;
});
--------------------------------------------------------------------------------
/*
@@使两个 Div 高度一样
@@有时你也许想让两个 div 拥有同样高度,不管它们里面有什么内容:
*/
$('.div').css('min-height', $('.main-div').height());
该例设置了 min-height,意味着它可以比主要 div 更大,但永远不能更小。但有一个更加灵活的方法是遍历一组元素的设置,然后将高度设为元素中的最高值:
var $columns = $('.column');
var height = 0;
$columns.each(function () {
if ($(this).height() > height) {
height = $(this).height();
}
});
$columns.height(height);
如果你想让所有列都有相同高度:
var $rows = $('.same-height-columns');
$rows.each(function () {
$(this).find('.column').height($(this).height());
}); 
--------------------------------------------------------------------------------
/*
@@在新标签/窗口打开站外链接
@@在一个新标签或者新窗口中打开外置链接,并确保站内链接会在相同的标签或窗口中打开:
*/
$('a[href^="http"]').attr('target', '_blank');
$('a[href^="//"]').attr('target', '_blank');
$('a[href^="' + window.location.origin + '"]').attr('target', '_self');
--------------------------------------------------------------------------------
/*
@@通过文本找到元素
@@通过使用 jQuery 中的 contains() 选择器,你可以找到某个元素中的文本。如果文本不存在,该元素将会隐藏:
*/
var search = $('#search').val();
$('div:not(:contains("' + search + '"))').hide();
--------------------------------------------------------------------------------
/*
@@视觉改变触发
@@当用户焦点在另外一个标签上,或重新回到标签时,触发 JavaScript:
*/
$(document).on('visibilitychange', function (e) {
if (e.target.visibilityState === "visible") {
console.log('Tab is now in view!');
} else if (e.target.visibilityState === "hidden") {
console.log('Tab is now hidden!');
}
});
--------------------------------------------------------------------------------
/*
@@Ajax 调用的错误处理
@@当某次 Ajax 调用返回 404 或 500 错误,就会执行错误处理。但如果没有定义该处理,其他 jQuery 代码或许会停止工作。可以通过下面这段代码定义一个全局 Ajax 错误处理
*/
$(document).ajaxError(function (e, xhr, settings, error) {
console.log(error);
});
--------------------------------------------------------------------------------
/*
@@插件链式调用
@@jQuery 支持链式调用插件,以减缓反复查询 DOM,并创建多个 jQuery 对象。看下面示例代码
*/
$('#elem').show();
$('#elem').html('bla');
$('#elem').otherStuff();
上面这段代码,可以通过链式操作大大改进:
$('#elem').show().html('bla').otherStuff();
还有另外一种方法,把元素缓存在变量中(前缀是 $ ):
var $elem = $('#elem');
$elem.hide();
$elem.html('bla');
$elem.otherStuff();
--------------------------------------------------------------------------------
/*
@@Jq 遍历 全选 全不选 反选
@@
*/
//全选 全不选
$('#checkAll').click(function () {
//判断是否被选中
var bischecked = $('#checkAll').is(':checked');
var fruit = $('input[name="check"]');
bischecked ? fruit.attr('checked', true) : fruit.attr('checked', false);
});
//反选 遍历checkbox 如果当前为选中 就设置为 不选中 反之相同
$("#tabVouchList tr").each(function () {
if ($("td:eq(0) input[name='check']", $(this)).is(':checked')) {
$(this).attr('checked', false);
} else {
$(this).attr('checked', true);
}
});

以上所述是小编给大家提供的js小技巧总结,希望对大家有所帮助!

Javascript 相关文章推荐
javascript将浮点数转换成整数的三个方法
Jun 23 Javascript
详解jquery中$.ajax方法提交表单
Nov 03 Javascript
使用jquery菜单插件HoverTree仿京东无限级菜单
Dec 18 Javascript
javascript实现无限级select联动菜单
Jan 02 Javascript
JS实现常见的TAB、弹出层效果(TAB标签,斑马线,遮罩层等)
Oct 08 Javascript
js中substr,substring,indexOf,lastIndexOf,split,replace的用法详解
Nov 09 Javascript
js放大镜放大购物图片效果
Jan 18 Javascript
js字符串与Unicode编码互相转换
May 17 Javascript
jquery处理checkbox(复选框)是否被选中实例代码
Jun 12 jQuery
JavaScript Canvas实现验证码
Aug 02 Javascript
关于Vue中axios的封装实例详解
Oct 20 Javascript
微信小程序canvas实现签名功能
Jan 19 Javascript
Jquery为DIV添加click事件的简单实例
Jun 02 #Javascript
jquery中取消和绑定hover事件的实现代码
Jun 02 #Javascript
深入理解jQuery之事件移除
Jun 02 #Javascript
深入理解JQuery循环绑定事件
Jun 02 #Javascript
JQuery在循环中绑定事件的问题详解
Jun 02 #Javascript
Javascript字符串拼接小技巧(推荐)
Jun 02 #Javascript
Jquery对新插入的节点 绑定Click事件失效的解决方法
Jun 02 #Javascript
You might like
php url地址栏传中文乱码解决方法集合
2010/06/25 PHP
Ping服务的php实现方法,让网站快速被收录
2012/02/04 PHP
PHP Class&amp;Object -- PHP 自排序二叉树的深入解析
2013/06/25 PHP
解决PhpMyAdmin中导入2M以上大文件限制的方法分享
2014/06/06 PHP
ThinkPHP学习笔记(一)ThinkPHP部署
2014/06/22 PHP
PHP合并数组+号和array_merge的区别
2015/06/25 PHP
Laravel路由研究之domain解决多域名问题的方法示例
2019/04/04 PHP
关于B/S判断浏览器断开的问题讨论
2008/10/29 Javascript
ext 代码生成器
2009/08/07 Javascript
Javascript 判断客户端浏览器类型代码
2010/03/01 Javascript
用Jquery.load载入页面实现局部刷新
2014/01/22 Javascript
Javascript中prototype属性实现给内置对象添加新的方法
2015/05/14 Javascript
javascript求日期差的方法
2016/03/02 Javascript
JS实现table表格数据排序功能(可支持动态数据+分页效果)
2016/05/26 Javascript
jQuery插件编写步骤详解
2016/06/03 Javascript
利用JS提交表单的几种方法和验证(必看篇)
2016/09/17 Javascript
AngularJS实现给动态生成的元素绑定事件的方法
2016/12/14 Javascript
jquery validation验证表单插件
2017/01/07 Javascript
Angular1.x复杂指令实例详解
2017/03/01 Javascript
jQuery实现字体颜色渐变效果的方法
2017/03/29 jQuery
JS实现同一DOM元素上onClick事件与onDblClick事件并存的解决方法
2018/06/07 Javascript
JS实现图片上传多次上传同一张不生效的处理方法
2018/08/06 Javascript
[41:17]VG vs Optic 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
[01:57]2018年度DOTA2最具潜力解说-完美盛典
2018/12/16 DOTA
使用BeautifulSoup爬虫程序获取百度搜索结果的标题和url示例
2014/01/19 Python
python字符串替换示例
2014/04/24 Python
跟老齐学Python之让人欢喜让人忧的迭代
2014/10/02 Python
Python定义二叉树及4种遍历方法实例详解
2018/07/05 Python
Python 实现遥感影像波段组合的示例代码
2019/08/04 Python
Europcar葡萄牙:葡萄牙汽车和货车租赁
2017/10/13 全球购物
中学运动会广播稿
2014/01/19 职场文书
金融事务专业求职信
2014/04/25 职场文书
倡议书格式
2014/08/30 职场文书
运动会铅球比赛加油稿
2014/09/26 职场文书
纪检监察立案决定书
2015/06/24 职场文书
cf战队宣传语
2015/07/13 职场文书