分享javascript、jquery实用代码段


Posted in Javascript onOctober 20, 2016

本文实例为大家简单分享javascript、jquery实用demo,供大家参考,具体内容如下

javascript判断H5页面离开

function onbeforeunloadFn(){
 console.log('离开页面');
 //...code
}
function showOnbeforeunload(flags){
 if(flags){
 document.body.onbeforeunload = onbeforeunloadFn;
 }else{
 document.body.onbeforeunload = null;
 }
}
$(function(){
 showOnbeforeunload(true);
})

jq判断img标签图片地址是否已经加载完毕

imgStatus = 0;
 $("img").each(function(){
 if(this.complete){/*this.complete代表图片加载完成*/
  imgStatus++;
 }
 });

iframe获取内容-和设置

if($(".ad_show iframe").size() > 0 ){
 $(".ad_show iframe").attr("id","iframead");/*设置iframe的id*/
 /*获取id为iframead的iframe的dom对象*/
 var iframebox = document.getElementById("iframead").contentWindow;
 /*设置兜底内容*/
 iframebox.document.body.innerText = "1234";
}

javascript获取浏览器上一页的url

/*返回上一次url,如果是新窗口则不能获取到*/
var beforeUrl = document.referrer;

关于头疼的移动端点击冒泡事件

<script>
$(".class").live('tap',function(oEvent){
 e = window.event || oEvent;
 if(e.stopPropagation){
 e.stopPropagation();
 }else{
 e.cancelBubble = true;
 }
 e.preventDefault();
});
</script>
/*虽说tap事件可以阻止大部分冒泡事件,但是还是有一小部分移动端不吃你这套,那么有另外一个解决办法*/
/*将层级间的事件通过H5属性data-flag="true"来控制*/
<!--html-->
<div class="parentTap" data-flag="true">
 <div class="childTap" data-flag="false">
 <div class="childsTap" data-flag="false">
  ....
 </div>
 </div>
</div>
<!--给父级parentTap绑定一个点击事件-->
<!--给子级childTap绑定一个点击事件-->
<!--给子孙级childsTap绑定一个点击事件-->
<script type="text/javascript">
 var bindInit = function(className){
 if($(className).size() > 0){
  $(className).on('tap',function(oEvent){
  e = window.event || oEvent;if(e.stopPropagation){e.stopPropagation();}else{e.cancelBubble = true;}e.preventDefault();
  var flag = $(this).data('flag');
  if(flag){/*为true时允许点击进入事件*/
   /* code... */
  }
  });
 }
 }
 $(function(){
 bindInit('.parentTap');
 bindInit('.childTap');
 bindInit('.childsTap');
 });
</script>

简单倒计时功能

<div class="newTime" data-end="2016-10-13 23:59:59" data-now="2016-10-13 03:59:59">
 <div class="t_d"></div>
 <div class="t_h"></div>
 <div class="t_m"></div>
 <div class="t_s"></div>
</div>
 <script type="text/javascript">
 /*倒计时*/
 var timeDown = {
  GetRTime: function (timeId,oldNowTime) {
  var tempTime;/*保存上一次时间*/
  if(oldNowTime){
   tempTime = new Date(oldNowTime.getTime() + 1000);/*如果有上一次时间则赋值*/
   /*console.log(tempTime);*/
  }
  var EndTime = new Date($("#" + timeId).data("end"));/*获取结束时间*/
  if (!tempTime) {
   if ($("#" + timeId).data("now") == "" || $("#" + timeId).data("now") == "null") {
   var NowTime = new Date();
   } else {
   var NowTime = new Date($("#" + timeId).data("now"));/*取开始时间*/
   }
  } else {
   var NowTime = tempTime;
  }
  if (EndTime.getTime() >= NowTime.getTime()) {/*判断时间*/
   var t = EndTime.getTime() - NowTime.getTime();/*得到结束时间减去开始时间的时间戳*/
   var d = Math.floor(t / 1000 / 60 / 60 / 24);/*日*/
   var h = Math.floor(t / 1000 / 60 / 60 % 24);/*时*/
   var m = Math.floor(t / 1000 / 60 % 60);/*分*/
   var s = Math.floor(t / 1000 % 60);/*秒*/
   /*将时间填入对应的html中*/
   $(".t_d", "#" + timeId).html((d > 9 ? '' : '0') + d);
   $(".t_h", "#" + timeId).html((h > 9 ? '' : '0') + h);
   $(".t_m", "#" + timeId).html((m > 9 ? '' : '0') + m);
   $(".t_s", "#" + timeId).html((s > 9 ? '' : '0') + s);
   tempTime = new Date(NowTime.getTime() + 1000);/*将开始时间+1秒*/
   setTimeout(function () {
   timeDown.GetRTime(timeId,NowTime);/*等待一秒后继续执行*/
   }, 1000);
  } else if (EndTime.getTime() == NowTime.getTime()) {/*当时间相等时要做处理的code*/
   $("#"+timeId).hide();
  }
  }
 }
 var t=0;
 if ($(".newTime").size() > 0) {
  $(".newTime").each(function(){
  var timeId="timeOut"+t;
  $(this).attr("id",timeId);/*设置多个倒计时时指定唯一id*/
  t++;
  timeDown.GetRTime(timeId,null);/*开始调用*/
  });
 }
 </script>

jQuery的节点操作

jQuery.parent(expr) /*找父亲节点,可以传入expr进行过滤,比如$("span").parent()或者$("span").parent(".class")*/

jQuery.parents(expr) /*类似于jQuery.parents(expr),但是是查找所有祖先元素,不限于父元素*/

jQuery.children(expr) /*返回所有子节点,这个方法只会返回直接的孩子节点,不会返回所有的子孙节点*/

jQuery.contents() /*返回下面的所有内容,包括节点和文本。这个方法和children()的区别就在于,包括空白文本,也会被作为一个*/

/*
 jQuery对象返回,children()则只会返回节点

 jQuery.prev(),返回上一个兄弟节点,不是所有的兄弟节点

 jQuery.prevAll(),返回所有之前的兄弟节点

 jQuery.next(),返回下一个兄弟节点,不是所有的兄弟节点

 jQuery.nextAll(),返回所有之后的兄弟节点

 jQuery.siblings(),返回兄弟姐妹节点,不分前后

 jQuery.find(expr),跟jQuery.filter(expr)完全不一样。
 jQuery.filter()是从初始的jQuery对象集合中筛选出一部分,
 而jQuery.find()的返回结果,不会有初始集合中的内容,
 比如$("p"),find("span"),是从<p>元素开始找<span>,等同于$("p span")
*/

js中if判断语句中的in语法

/*
在js代码中
通常的if判断语句会这样写:
*/
if(1 == 1){
 alert("1等于1");
}else{
 alert("1不等于1");
}
/*而在in写法下可以这样:*/
if(1 in window){
 alert("window包含1");
}else{
 alert("window不包含1");
}

js的try-catch

try{
 foo.bar();
}catch(e){
 console.log(e.name + ":" + e.message);
}
try{
 throw new Error("Whoops!");
}catch(e){
 console.log(e.name + ":" + e.message);
} 
/*
改js代码会捕获一个异常错误:
 因为foo.bar();是未定义的;
 因此在js代码中如果没有异常捕获,整个页面都不会继续解析.
 从而导致页面加载失败.
 这里就需要通过try-catch来异常捕获这种错误,并把他反馈出来

目前我们可能得到的系统异常主要包含以下6种:
 EvalError: raised when an error occurs executing code in eval()
 翻译:当一个错误发生在eval()执行代码 
 RangeError: raised when a numeric variable or parameter is outside of its valid range 
 翻译:当一个数值变量或参数的有效范围之外
 ReferenceError: raised when de-referencing an invalid reference 
 翻译:引用无效的引用
 SyntaxError: raised when a syntax error occurs while parsing code in eval()
 翻译:语法错误,当发生语法错误在eval()解析代码里
 TypeError: raised when a variable or parameter is not a valid type 
 翻译:错误类型:当一个变量或参数不是一个有效的类型
 URIError: raised when encodeURI() or decodeURI() are passed invalid parameters 
 翻译:调用encodeURI()或decodeURI()时,传入的参数是不通过无效的

以下是异常捕获是的属性:
 Error具有下面一些主要属性:
 description: 错误描述 (仅IE可用). 
 fileName: 出错的文件名 (仅Mozilla可用). 
 lineNumber: 出错的行数 (仅Mozilla可用). 
 message: 错误信息 (在IE下同description) 
 name: 错误类型. 
 number: 错误代码 (仅IE可用). 
 stack: 像Java中的Stack Trace一样的错误堆栈信息 (仅Mozilla可用).
*/ 
/*
 如要判断异常信息的类型,可在catch中进行判断:
 */

try {
 coo.bar();//捕获异常,ReferenceError:引用无效的引用
}catch(e){
 console.log(e instanceof EvalError);
 console.log(e instanceof RangeError);
 if(e instanceof EvalError){ 
 console.log(e.name + ":" + e.message);
 }else if(e instanceof RangeError){
 console.log(e.name + ":" + e.message); 
 }else if(e instanceof ReferenceError){
 console.log(e.name + ":" + e.message); 
 }
}

js中typeof和instanceof区别

/*先捕获异常,抛出异常*/
try {
 throw new myBlur(); // 抛出当前对象 
}catch(e){
 console.log(typeof(e.a)); //返回function类型
 if(e.a instanceof Function){//instanceof用于判断一个变量是否某个对象的实例,true
 console.log("是一个function方法");
 e.a();//执行这个方法,输出"失去焦点"
 }else{
 console.log("不是一个function方法");
 }
}
function myBlur(){
 this.a = function(){
 console.log("失去焦点");
 };
}

/*
 通畅typeof一般只能返回如下几个结果:
 number,boolean,string,function,object,undefined;
 如果要用if做比较则比较后面要用双引号引起来
*/
 if(typeof(param) == "object"){
 alert("该参数等于object类型");
 }else{
 alert("该参数不等于object类型");
 }

/*又如:*/
console.log(Object instanceof Object);//true
console.log(Function instanceof Function);//true 
console.log(Number instanceof Number);//false
console.log(String instanceof String);//false
console.log(Function instanceof Object);//true
console.log(Foo instanceof Function);//true
console.log(Foo instanceof Foo);//false

HTML5缓存sessionStorage

sessionStorage.getItem(key)//获取指定key本地存储的值
sessionStorage.setItem(key,value)//将value存储到key字段
sessionStorage.removeItem(key)//删除指定key本地存储的值
sessionStorage.length//sessionStorage的项目数

/*
sessionStorage与localStorage的异同:
 sessionStorage和localStorage就一个不同的地方,
 sessionStorage数据的存储仅特定于某个会话中,
 也就是说数据只保持到浏览器关闭,当浏览器关闭后重新打开这个页面时,之前的存储已经被清除。
 而localStorage是一个持久化的存储,它并不局限于会话

sessionStorage和localStorage的clear()函数的用于清空同源的本地存储数据:
 比如localStorage.clear(),它将删除所有同源的本地存储的localStorage数据,
 而对于SessionStorage,它只清空当前会话存储的数据。

sessionStorage和localStorage具有相同的方法storage事件:
 在存储事件的处理函数中是不能取消这个存储动作的。
 存储事件只是浏览器在数据变化发生之后给你的一个通知。
 当setItem(),removeItem()或者clear() 方法被调用,
 并且数据真的发生了改变时,storage事件就会被触发。
 注意这里的的条件是数据真的发生了变化。也就是说,
 如果当前的存储区域是空的,你再去调用clear()是不会触发事件的。
 或者你通过setItem()来设置一个与现有值相同的值,事件也是不会触发的。
 当存储区域发生改变时就会被触发。
*/

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript实现划词标记+划词搜索功能
Mar 06 Javascript
jquery序列化表单以及回调函数的使用示例
Jul 02 Javascript
JS将滑动门改为选项卡(需鼠标点击)的实现方法
Sep 27 Javascript
JavaScript简单遍历DOM对象所有属性的实现方法
Oct 21 Javascript
Jquery与Bootstrap实现后台管理页面增删改查功能示例
Jan 22 Javascript
手把手教你搭建ES6的开发运行环境
Jul 11 Javascript
Vue-Router2.X多种路由实现方式总结
Feb 09 Javascript
浅谈webpack+react多页面开发终极架构
Nov 11 Javascript
ES6基础之 Promise 对象用法实例详解
Aug 22 Javascript
在vue中使用Echarts画曲线图的示例
Oct 03 Javascript
TypeScript魔法堂之枚举的超实用手册
Oct 29 Javascript
深入了解Vue动态组件和异步组件
Jan 26 Vue.js
基于原生js淡入淡出函数封装(兼容IE)
Oct 20 #Javascript
纯JavaScript手写图片轮播代码
Oct 20 #Javascript
Zabbix添加Node.js监控的方法
Oct 20 #Javascript
Javascript实现图片懒加载插件的方法
Oct 20 #Javascript
Vue.js Ajax动态参数与列表显示实现方法
Oct 20 #Javascript
探究Vue.js 2.0新增的虚拟DOM
Oct 20 #Javascript
Javascript 创建类并动态添加属性及方法的简单实现
Oct 20 #Javascript
You might like
php判断手机访问还是电脑访问示例分享
2014/01/20 PHP
PHP图片处理之使用imagecopy函数添加图片水印实例
2014/11/19 PHP
PHP Socket网络操作类定义与用法示例
2017/08/30 PHP
JS代码格式化和语法着色V2
2006/10/14 Javascript
xmlHTTP实例
2006/10/24 Javascript
JavaScript CSS修改学习第六章 拖拽
2010/02/19 Javascript
filters.revealTrans.Transition使用方法小结
2010/08/19 Javascript
javascript确认框的三种使用方法
2013/12/17 Javascript
Nodejs实现的一个静态服务器实例
2014/12/06 NodeJs
深入理解JavaScript系列(27):设计模式之建造者模式详解
2015/03/03 Javascript
js代码实现点击按钮出现60秒倒计时
2021/01/28 Javascript
js原型链与继承解析(初体验)
2016/05/09 Javascript
js与jquery正则验证电子邮箱、手机号、邮政编码的方法
2016/07/04 Javascript
jQuery版AJAX简易封装代码
2016/09/14 Javascript
百度地图JavascriptApi Marker平滑移动及车头指向行径方向
2017/03/13 Javascript
详解vue事件对象、冒泡、阻止默认行为
2017/03/20 Javascript
js学习总结_轮播图之渐隐渐现版(实例讲解)
2017/07/17 Javascript
vue.js中$set与数组更新方法
2018/03/08 Javascript
vue 父组件通过$refs获取子组件的值和方法详解
2019/11/07 Javascript
JavaScript数组及常见操作方法小结
2019/11/13 Javascript
[01:05:07]DOTA2-DPC中国联赛 正赛 DLG vs Dragon BO3 第一场2月1日
2021/03/11 DOTA
Python urlopen 使用小示例
2008/09/06 Python
python实现提取百度搜索结果的方法
2015/05/19 Python
Python随机生成手机号、数字的方法详解
2017/07/21 Python
Python将多份excel表格整理成一份表格
2018/01/03 Python
python 接口测试response返回数据对比的方法
2018/02/11 Python
python中time库的实例使用方法
2019/10/31 Python
python 字典套字典或列表的示例
2019/12/16 Python
keras.layer.input()用法说明
2020/06/16 Python
CSS3中的常用选择器使用示例整理
2016/06/13 HTML / CSS
比利时买床:Beter Bed
2017/12/06 全球购物
大学毕业自我评价
2014/02/02 职场文书
领导干部廉政自律承诺书
2014/05/26 职场文书
先进教师个人总结
2015/02/11 职场文书
预备党员党支部意见
2015/06/02 职场文书
课改心得体会范文
2016/01/25 职场文书