阻止冒泡、默认行为、事件捕获

 /* funname preventEventPropagation
* desc 阻止冒泡事件&阻止默认行为&阻止事件捕获
* params {name: string}参数名称
* return {string or null}
*/
var preventEventPropagation = function(evt) {
var e = evt || window.event;
if (e) {
e.preventDefault();
e.stopPropagation();
}
return false;
};

获取地址参数

 /* funname getQueryString
* desc 获取地址参数
* params {name: string}参数名称
* return {string or null}
*/
var getQueryString = function(name) {
var r, reg;
reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
r = window.location.search.substr(1).match(reg);
if (r !== null) {
return r[2]; //不解码
}
return null;
};

判断微信环境


/*
*desc:判断微信环境
*params:null
*/
var isInWechat = function() {
var ua = navigator.userAgent.toLowerCase();
if (ua.match(/MicroMessenger/i) == "micromessenger") {
return true;
} else {
return false;
}
};

获取环境参数


/*
*funname:platformFn
*des:获取环境参数
*params:
*return: [object]
*/
var platformFn = function() {
var u = navigator.userAgent,
app = navigator.appVersion;
return {
webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
android: u.indexOf('Android') > -1 || u.indexOf('Adr') > -1, //android终端
iPhone: u.indexOf('iPhone') > -1, //是否为iPhone或者QQHD浏览器
iPad: u.indexOf('iPad') > -1, //是否iPad
webApp: u.indexOf('Safari') == -1, //是否web应该程序,没有头部与底部
weixin: u.indexOf('MicroMessenger') > -1, //是否微信 (2015-01-22新增)
};
};

判断是否为数组


// 判断是否为数组
/*
*funname:isArray
*des:判断是否为数组
*params: [array] arr
*return: [bolean]
*/
function isArray(arr) {
if (arr typeof arr === 'object' && arr.constructor == Array) {
return true;
}
return false;
}

数组除重


// 数组除重
/*
*funname:arrayUnique
*des:数组去重
*params: [array] arr
*return: [array]
*/
var arrayUnique = function(arr) {
var newArr = [];
var temp = {};
var len = arr.length;
for (var index = 0; index < len; index++) {
var key = typeof(arr[index]) + arr[index];
if (temp[key] !== 1) {
newArr.push(arr[index]);
temp[key] = 1;
}
}
return newArr;
};

获取cookie

 /*
*funname:getCookie
*des:获取cookie
*params: [array] arr
*return: [array]
*/
function getCookie(c_name) {
if (document.cookie.length > 0) {
c_start = document.cookie.indexOf(c_name + "=")
if (c_start != -1) {
c_start = c_start + c_name.length + 1
c_end = document.cookie.indexOf(";", c_start)
if (c_end == -1) c_end = document.cookie.length
return unescape(document.cookie.substring(c_start, c_end))
}
}
return ""
}

设置cookie

 /*
*funname:setCookie
*des:设置cookie
*params: [string] c_name,[string] value,expiredays
*return: [array]
*/
function setCookie(c_name, value, expiredays) {
var exdate = new Date()
exdate.setDate(exdate.getDate() + expiredays)
document.cookie = c_name + "=" + escape(value) +
((expiredays == null) ? "" : ";expires=" + exdate.toGMTString())
}

检测cookie

 /*
*funname:checkCookie
*des:检测cookie
*params:
*return:
*/
function checkCookie() {
username = getCookie('username')
if (username != null && username != "") {
return true;
} else {
return false;
}
}

获取localstorage

 /*
*funname:getLocalStorage
*des:获取localstorage
*params: [string] key
*return: [string]
*/
function getLocalStorage(key) {
if (localStorage) {
return localStorage.getItem(key);
} else {
// 使用cookie获取
return getCookie(key);
}
return '';
}

设置localstorage

 /*
*funname:setLocalStorage
*des:设置localstorage
*params:
*return: null
*/
function setLocalStorage(key, value, expiredays) {
if (localStorage) {
console.log(setLocalStorage);
localStorage.setItem(key, value);
} else {
// 使用cookie保存
setCookie(key, value, expiredays);
}
}

清空localstorage

/*
*funname:clearLocalStorage
*des:清空localstorage
*params: [string] key
*return: [string]
*/
function clearLocalStorage(key) {
if (localStorage) {
localStorage.removeItem(key);
} else {
// 使用cookie获取
clearCookie(key)
}
}

解决ios滚动问题的插件

 /**
* ScrollFix v0.1
* http://www.joelambert.co.uk
*
* Copyright 2011, Joe Lambert.
* Free to use under the MIT license.
* http://www.opensource.org/licenses/mit-license.php
* des: 解决ios滚动问题的插件
*/ var ScrollFix = function(elem) {
// Variables to track inputs
var startY, startTopScroll; elem = elem || document.querySelector(elem); // If there is no element, then do nothing
if (!elem)
return; // Handle the start of interactions
elem.addEventListener('touchstart', function(event) {
startY = event.touches[0].pageY;
startTopScroll = elem.scrollTop; if (startTopScroll <= 0)
elem.scrollTop = 1; if (startTopScroll + elem.offsetHeight >= elem.scrollHeight)
elem.scrollTop = elem.scrollHeight - elem.offsetHeight - 1;
}, false);
};

动态加载js

 /*
*funname:loadScript
*des:动态加载js
*params: [string] filepath,[function] onloadCallback
*return: null
*/
function loadScript(filepath, onloadCallback) {
var scriptDom = document.createElement("script");
scriptDom.onload = scriptDom.onreadystatechange = onloadCallback;
scriptDom.type = "text/javascript";
scriptDom.src = filepath;
document.body.appendChild(scriptDom);
}

克隆对象

/*
*desc:针对纯 JSON 数据对象的深拷贝
*params:[object] obj
*/
var cloneObj = function(obj) {
if (obj) {
var newObj = JSON.stringify(obj)
newObj = JSON.parse(newObj)
return newObj
}
return null
}; 局限性: - 无法复制函数
- 原型链没了,对象就是object,所属的类没了。

移动端返回上一页

/*
*desc:移动端返回上一页
*params:
*/
var appGoBack = function() {
if (!url || url == '') {
window.history.go(-1);
setTimeout(function() {
// 如果不支持history.go,返回首页
location.replace('/');
}, 300);
} else {
// ios的.history.go和history.back有bug
location.replace(url);
}
return false;
}

获取随机数

/*
* funname:GetRandomNum
*params:[number]
* des:获取随机数
*return:
*/
var getRandom = function(Min, Max) {   
var Range = Max - Min;   
var Rand = Math.random();   
return (Min + Math.round(Rand * Range));   
};

11位手机号码验证

function checkPhone(phone ){
if(/^1(3|4|5|7|8)\d{9}$/.test(phone)){
return true;
}
return false;
}

判断是否是汉字

function isChinese(str){
var reg = /[\u4E00-\u9FA5\uF900-\uFA2D]/;
return reg.test(str);
} //u4e00-u9fbf: unicode CJK(中日韩)统一表意字符。u9fa5后至u9fbf为空
//uF900-uFAFF: unicode CJK 兼容象形文字 。uFA2D后至uFAFF为空

不定期更新,看心情更新~

参考链接:http://www.cnblogs.com/baiyyg...

本文转载于:猿2048js常用的函数库

js常用的函数库的更多相关文章

  1. JS常用自定义函数总结

    JS常用自定义函数总结   1.原生JavaScript实现字符串长度截取 2.原生JavaScript获取域名主机 3.原生JavaScript清除空格 4.原生JavaScript替换全部 5.原 ...

  2. JavaScript使用技巧(1)——JS常用的函数

    1.字符串对象函数和属性 函数: charAt():返回在指定位置的字符. charCodeAt():返回在指定的位置的字符的 Unicode 编码. concat():连接字符串. indexOf( ...

  3. js常用字符串函数

    // JS字符串 //1.replace字符串替换,只能换第一部分,就是说多个字符相同,只能换下最先的 var str='helloworld!'; alert(str.replace('llo',' ...

  4. Js常用的函数

    1.用于对正则表达式的函数: var pattern=/\d{3}-\d{2}-\d{4}/;//这里产生的是一个object类型 alert(pattern.test("cscscscs& ...

  5. JS常用工具函数(持续记录)

    1.设置获取cookie //方式1 //设置cookie function SetCookie(name, value)//两个参数,一个是cookie的名字,一个是值 { var Days = 3 ...

  6. 前端开发 —— js 常用工具函数(utilities)

    1. 时间 function getCurTime() { var date = new Date(); return date.toLocaleTimeString(); } date.toLoca ...

  7. JS常用工具函数

    /** * Created by gaojun-pd on 2016/10/27. */ var Util = { /** * 1.判断非空 * 2.获取字符串真实长度 汉字算两位 * 3.判断参数类 ...

  8. JS - 常用效果代码库 (四)

    1.首字母大写示例: var value = “一段文本或一个参数”; value = value.toString() return value.charAt(0).toUpperCase() + ...

  9. js常用Matn函数的操练

    Math.PI console.log(Math.PI); 随机数以及向下取整 这是一个能实现从a-b之间随机打印一个整数 function rand_s(a, b) { var x = a + (b ...

随机推荐

  1. Python:对元组使用关键字in

    如果in的左边是个含有多个元素的元组对象 例如 ('a','b') in L 那么L在什么情况下,这个式子会输出True呢? 答案是,L中必须也有一个和想要查找的元组一模一样的元组才行,比如: L=[ ...

  2. 面试官:Redis中列表的内部实现方式是什么?

    在面试间里等候时,感觉这可真暖和呀,我那冰冷的出租屋还得盖两层被子才能睡着.正要把外套脱下来,我突然听到了门外的脚步声,随即门被打开,一位眉毛弯弯嘴唇红红的小姐姐走了进来,甜甜的香水味立刻钻进了我的鼻 ...

  3. SQL从零到迅速精通【规则和约束】

    1.[创建规则] 为stu_info表定义一个规则,指定其成绩列的值必须大于0,小于100,输入语句如下. USE test_db; GO CREATE RULE rule_score AS @sco ...

  4. Vue-表单验证-全选-反选-删除-批量删除

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  5. CF877F题解

    题目大意 有一个序列,每个位置上有 \(1\) 或 \(2\) 两种元素若干,每次询问一个区间,求这个区间有多少个子区间满足 \(1\) 类元素恰好比 \(2\) 类元素多 \(k\) 个. 莫队 要 ...

  6. 《Shader入门精要》第11章-11.3.1流动的河流中的offset.x的解释

    在我学习入门精要的时候,经常遇到不解释api,甚至是关键代码的实现原理. 11.3.1流动的河流中的offset.x的sin函数查了一下好像大家也都是书上原话直接复制,现在好不容易想明白了希望能帮到和 ...

  7. 手写 Vue2 系列 之 patch —— diff

    前言 上一篇文章 手写 Vue2 系列 之 初始渲染 中完成了原始标签.自定义组件.插槽的的初始渲染,当然其中也涉及到 v-bind.v-model.v-on 指令的原理.完成首次渲染之后,接下来就该 ...

  8. 前端性能优化 —— 使用 BMP 图片代替 canvas.toDataURL

    前端开发中有时需要将 canvas 的内容导出成图片文件,例如供 CSS 使用,通常会使用 canvas.toDataURL,兼容性好并且简单. 不过 canvas.toDataURL 显然是非常低效 ...

  9. NET经典书籍必读

    C#与.NET框架,入门 + 进阶 + 精通,外加并发编程实例,10本C#图书,一本都不能少. 1.<Learning hard C#学习笔记> 作者:李志  书号:978-7-115-3 ...

  10. Matplotlib库基础_一

    Matplotlib库基础 •pyplot绘制坐标 plt.plot(x,y,format_string,**kwargs) x:x轴数据,列表或数组,可选 y:y轴数据,列表或数组 format_s ...