前端设计师们最常用的JS代码汇总


Posted in Javascript onSeptember 25, 2016

逛社区时看到的文章,我修改调整了内容,如果大家觉得也有帮助 可以收藏下~

HTML5 DOM 选择器

// querySelector() 返回匹配到的第一个元素
var item = document.querySelector('.item');
console.log(item);

// querySelectorAll() 返回匹配到的所有元素,是一个nodeList集合
var items = document.querySelectorAll('.item');
console.log(items[0]);

阻止默认行为

// 原生js
document.getElementById('btn').addEventListener('click', function (event) {
  event = event || window.event;

  if (event.preventDefault){
    // w3c方法 阻止默认行为
    event.preventDefault();
  } else{
    // ie 阻止默认行为
    event.returnValue = false;
  }
}, false);

// jQuery
$('#btn').on('click', function (event) {
  event.preventDefault();
});

阻止冒泡

// 原生js
document.getElementById('btn').addEventListener('click', function (event) {
  event = event || window.event;
  if (event.stopPropagation){
    // w3c方法 阻止冒泡
    event.stopPropagation();
  } else{
    // ie 阻止冒泡
    event.cancelBubble = true;
  }
}, false);
// jQuery
$('#btn').on('click', function (event) {
  event.stopPropagation();
});

鼠标滚轮事件

$('#content').on("mousewheel DOMMouseScroll", function (event) { 
  // chrome & ie || // firefox
  var delta = (event.originalEvent.wheelDelta && (event.originalEvent.wheelDelta > 0 ? 1 : -1)) || (event.originalEvent.detail && (event.originalEvent.detail > 0 ? -1 : 1)); 
  
  if (delta > 0) { 
    // 向上滚动
    console.log('mousewheel top');
  } else if (delta < 0) {
    // 向下滚动
    console.log('mousewheel bottom');
  } 
});

检测浏览器是否支持svg

function isSupportSVG() { 
  var SVG_NS = 'http://www.w3.org/2000/svg';
  return !!document.createElementNS &&!!document.createElementNS(SVG_NS, 'svg').createSVGRect; 
} 
// 测试
console.log(isSupportSVG());

检测浏览器是否支持canvas

function isSupportCanvas() {
  if(document.createElement('canvas').getContext){
    return true;
  }else{
    return false;
  }
}
// 测试,打开谷歌浏览器控制台查看结果
console.log(isSupportCanvas());

检测是否是微信浏览器

function isWeiXinClient() {
  var ua = navigator.userAgent.toLowerCase(); 
  if (ua.match(/MicroMessenger/i)=="micromessenger") { 
    return true; 
  } else { 
    return false; 
  }
}
// 测试
alert(isWeiXinClient());

jQuery 获取鼠标在图片上的坐标

$('#myImage').click(function(event){
  //获取鼠标在图片上的坐标 
  console.log('X:' + event.offsetX+'\n Y:' + event.offsetY); 
  
  //获取元素相对于页面的坐标 
  console.log('X:'+$(this).offset().left+'\n Y:'+$(this).offset().top);
});

验证码倒计时代码

<!-- dom -->
<input id="send" type="button" value="发送验证码">
// 原生js版本
var times = 60, // 临时设为60秒
  timer = null;
      
document.getElementById('send').onclick = function () {
  // 计时开始
  timer = setInterval(function () {
    times--;
    
    if (times <= 0) {
      send.value = '发送验证码';
      clearInterval(timer);
      send.disabled = false;
      times = 60;
    } else {
      send.value = times + '秒后重试';
      send.disabled = true;
    }
  }, 1000);
}

// jQuery版本
var times = 60,
  timer = null;
$('#send').on('click', function () {
  var $this = $(this);
  
  // 计时开始
  timer = setInterval(function () {
    times--;
    
    if (times <= 0) {
      $this.val('发送验证码');
      clearInterval(timer);
      $this.attr('disabled', false);
      times = 60;
    } else {
      $this.val(times + '秒后重试');
      $this.attr('disabled', true);
    }
  }, 1000);
});

常用的一些正则表达式

//匹配字母、数字、中文字符 
/^([A-Za-z0-9]|[\u4e00-\u9fa5])*$/ 
//验证邮箱 
/^\w+@([0-9a-zA-Z]+[.])+[a-z]{2,4}$/ 
//验证手机号 
/^1[3|5|8|7]\d{9}$/ 
//验证URL 
/^http:\/\/.+\./
//验证身份证号码 
/(^\d{15}$)|(^\d{17}([0-9]|X|x)$)/ 
//匹配中文字符的正则表达式 
/[\u4e00-\u9fa5]/ 
//匹配双字节字符(包括汉字在内) 
/[^\x00-\xff]/

js时间戳、毫秒格式化

function formatDate(now) { 
  var y = now.getFullYear();
  var m = now.getMonth() + 1; // 注意js里的月要加1 
  var d = now.getDate();
  var h = now.getHours(); 
  var m = now.getMinutes(); 
  var s = now.getSeconds();
  
  return y + "-" + m + "-" + d + " " + h + ":" + m + ":" + s; 
} 
var nowDate = new Date(2016, 5, 13, 19, 18, 30, 20);
console.log(nowDate.getTime()); // 获得当前毫秒数: 1465816710020
console.log(formatDate(nowDate));

js限定字符数(注意:一个汉字算2个字符)

<input id="txt" type="text">
//字符串截取
function getByteVal(val, max) {
  var returnValue = '';
  var byteValLen = 0;
  for (var i = 0; i < val.length; i++) {
    if (val[i].match(/[^\x00-\xff]/ig) != null) byteValLen += 2; else byteValLen += 1;
    if (byteValLen > max) break;
    returnValue += val[i];
  }
  return returnValue;
}
$('#txt').on('keyup', function () {
  var val = this.value;
  if (val.replace(/[^\x00-\xff]/g, "**").length > 14) {
    this.value = getByteVal(val, 14);
  }
});

js判断是否移动端及浏览器内核

var browser = { 
  versions: function() { 
    var u = navigator.userAgent; 
    return { 
      trident: u.indexOf('Trident') > -1, //IE内核 
      presto: u.indexOf('Presto') > -1, //opera内核 
      webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核 
      gecko: u.indexOf('Firefox') > -1, //火狐内核Gecko 
      mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端 
      ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios 
      android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android 
      iPhone: u.indexOf('iPhone') > -1 , //iPhone 
      iPad: u.indexOf('iPad') > -1, //iPad 
      webApp: u.indexOf('Safari') > -1 //Safari 
    }; 
  }
} 
if (browser.versions.mobile() || browser.versions.ios() || browser.versions.android() || browser.versions.iPhone() || browser.versions.iPad()) { 
  alert('移动端'); 
}

之前我用过一个检测客户端的库 觉得挺好用的,也推荐给大家 叫 device.js,大家可以 Googel 或 百度
GItHub仓库地址:https://github.com/matthewhudson/device.js

getBoundingClientRect() 获取元素位置

//它返回一个对象,其中包含了left、right、top、bottom四个属性
var myDiv = document.getElementById('myDiv');
var x = myDiv.getBoundingClientRect().left; 
var y = myDiv.getBoundingClientRect().top; 
// 相当于jquery的: $(this).offset().left、$(this).offset().top // js的:this.offsetLeft、this.offsetTop

HTML5全屏

function fullscreen(element) {
  if (element.requestFullscreen) {
    element.requestFullscreen();
  } else if (element.mozRequestFullScreen) {
    element.mozRequestFullScreen();
  } else if (element.webkitRequestFullscreen) {
    element.webkitRequestFullscreen();
  } else if (element.msRequestFullscreen) {
    element.msRequestFullscreen();
  }
}

fullscreen(document.documentElement);
Javascript 相关文章推荐
使用onbeforeunload属性后的副作用
Mar 08 Javascript
jquery创建并行对象或者合并对象的实现代码
Oct 10 Javascript
javascript:history.go()和History.back()的区别及应用
Nov 25 Javascript
20个实用的JavaScript技巧分享
Nov 28 Javascript
fastclick插件导致日期(input[type=&quot;date&quot;])控件无法被触发该如何解决
Nov 09 Javascript
巧用Vue.js+Vuex制作专门收藏微信公众号的app
Nov 03 Javascript
Vue分页组件实例代码
Apr 17 Javascript
微信小程序自定义模态对话框实例详解
Aug 16 Javascript
bootstrap实现点击删除按钮弹出确认框的实例代码
Aug 16 Javascript
electron制作仿制qq聊天界面的示例代码
Nov 26 Javascript
JavaScript实现五子棋游戏的方法详解
Jul 08 Javascript
Vue.js实现立体计算器
Feb 22 Javascript
JavaScript使用Range调色及透明度实例
Sep 25 #Javascript
JavaScript中原型链存在的问题解析
Sep 25 #Javascript
JavaScript制作颜色反转小游戏
Sep 25 #Javascript
JavaScript实现简单的日历效果
Sep 25 #Javascript
javascript实现根据汉字获取简拼
Sep 25 #Javascript
概述VUE2.0不可忽视的很多变化
Sep 25 #Javascript
微信小程序前端源码逻辑和工作流
Sep 25 #Javascript
You might like
PHP 应用程序的安全 -- 不能违反的四条安全规则
2006/11/26 PHP
php公用函数列表[正则]
2007/02/22 PHP
PHP编程最快明白(第一讲 软件环境和准备工作)
2010/10/25 PHP
php调用shell的方法
2014/11/05 PHP
PHP基于redis计数器类定义与用法示例
2018/02/08 PHP
YII框架实现自定义第三方扩展操作示例
2019/04/26 PHP
tbody元素支持嵌套的注意方法
2007/03/24 Javascript
javascript attachEvent和addEventListener使用方法
2009/03/19 Javascript
Mootools 1.2教程 排序类和方法简介
2009/09/15 Javascript
jquery 如何动态添加、删除class样式方法介绍
2012/11/07 Javascript
关于火狐(firefox)及ie下event获取的两种方法
2012/12/27 Javascript
Javascript模块化编程(一)AMD规范(规范使用模块)
2013/01/17 Javascript
javascript对select标签的控制(option选项/select)
2013/01/31 Javascript
ajax提交表单实现网页无刷新注册示例
2014/05/08 Javascript
JS实现双击编辑可修改状态的方法
2015/08/14 Javascript
javascript手风琴下拉菜单实现代码
2015/11/12 Javascript
JavaScript引用类型和基本类型详解
2016/01/06 Javascript
详解angular element()方法使用
2017/04/08 Javascript
小程序日历控件使用方法详解
2018/12/29 Javascript
对比Python中__getattr__和 __getattribute__获取属性的用法
2016/06/21 Python
Python中的with语句与上下文管理器学习总结
2016/06/28 Python
关于pycharm 切换 python3.9 报错 ‘HTMLParser‘ object has no attribute ‘unescape‘ 的问题
2020/11/24 Python
使用css3做0.5px的细线的示例代码
2018/01/18 HTML / CSS
Proenza Schouler官方网站:纽约女装和配饰品牌
2019/01/03 全球购物
面试后的英文感谢信
2014/02/01 职场文书
中文教师求职信
2014/02/22 职场文书
正科级干部考察材料
2014/05/29 职场文书
合作意向书
2014/07/30 职场文书
开展党的群众路线教育实践活动剖析材料
2014/10/13 职场文书
再婚婚前财产协议书范本
2014/10/19 职场文书
通知格式
2015/04/27 职场文书
工作会议简报
2015/07/20 职场文书
奖学金申请个人主要事迹材料
2015/11/04 职场文书
《钢铁是怎样炼成的》高中读后感
2019/08/07 职场文书
zabbix agent2 监控oracle数据库的方法
2021/05/13 Oracle
pytorch 实现多个Dataloader同时训练
2021/05/29 Python