js常用的函数库
阻止冒泡、默认行为、事件捕获
/* 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为空
不定期更新,看心情更新~
本文转载于:猿2048js常用的函数库
js常用的函数库的更多相关文章
- JS常用自定义函数总结
JS常用自定义函数总结 1.原生JavaScript实现字符串长度截取 2.原生JavaScript获取域名主机 3.原生JavaScript清除空格 4.原生JavaScript替换全部 5.原 ...
- JavaScript使用技巧(1)——JS常用的函数
1.字符串对象函数和属性 函数: charAt():返回在指定位置的字符. charCodeAt():返回在指定的位置的字符的 Unicode 编码. concat():连接字符串. indexOf( ...
- js常用字符串函数
// JS字符串 //1.replace字符串替换,只能换第一部分,就是说多个字符相同,只能换下最先的 var str='helloworld!'; alert(str.replace('llo',' ...
- Js常用的函数
1.用于对正则表达式的函数: var pattern=/\d{3}-\d{2}-\d{4}/;//这里产生的是一个object类型 alert(pattern.test("cscscscs& ...
- JS常用工具函数(持续记录)
1.设置获取cookie //方式1 //设置cookie function SetCookie(name, value)//两个参数,一个是cookie的名字,一个是值 { var Days = 3 ...
- 前端开发 —— js 常用工具函数(utilities)
1. 时间 function getCurTime() { var date = new Date(); return date.toLocaleTimeString(); } date.toLoca ...
- JS常用工具函数
/** * Created by gaojun-pd on 2016/10/27. */ var Util = { /** * 1.判断非空 * 2.获取字符串真实长度 汉字算两位 * 3.判断参数类 ...
- JS - 常用效果代码库 (四)
1.首字母大写示例: var value = “一段文本或一个参数”; value = value.toString() return value.charAt(0).toUpperCase() + ...
- js常用Matn函数的操练
Math.PI console.log(Math.PI); 随机数以及向下取整 这是一个能实现从a-b之间随机打印一个整数 function rand_s(a, b) { var x = a + (b ...
随机推荐
- Leaflet:Path、Polyline、Polygon、Rectangle、Circle、CircleMarker
下边介绍Vector Layer Path(Layer) Path是其他Vector Layer的父类,比如Polyline.Polygon.Rectangle.Circle.CircleMarker ...
- GeoServer-REST应用:基于Qt网络编程一键同步发布空间数据和样式至GeoServer
@ 目录 简介 配置 步骤 1.引入Qt网络模块 2.创建网络管理.网络响应.网络请求 3.创建工作空间 4.创建数据存储并上传数据 5.上传样式文件 6.图层发布 6.图 ...
- C++雾中风景18:C++20, 从concept开始
转眼间,C++20的标准已经发布快两年了.不少C++的开源项目也已经将标准升级到最新的C++20了,笔者也开启了新标准的学习历程了.所以借这系列的博文,记录下笔者学习新标准的一些心得与吐槽~~ 作为C ...
- Redis环境搭建-Linux单机
一.准备Linux 可以买云服务器,也可以用虚拟机,我用的是虚拟机Oracle VM VirtualBox 二.编译环境 1.检查linux下是否安装环境 yum list installed | g ...
- C#序列化和反序列化(json)
一,什么是Json? json是存储和交换文本信息的方法,类似xml.但是json比xml更小,更快,j更易于解析.并且json采用完全独立于语言的文本格式(即不依赖于各种编程语言),这些特性使jso ...
- HIve的基本使用
WHERE从表中筛选行: SELECT从表中查询指定的列: group by在列上做聚合. -- 假设数据文件的内容,字段之间以ASCII 001(ctrl-A)分隔,行之间以换行分隔. CREATE ...
- 所有整数型包装类对象值的比较,使用equals方法进行比较
一.整数型包装类对象值的比较,使用equals方法进行比较 题眼:整型包装类.值的比较 注:== :对于基本类型,比较的是值:对于引用类型,比较的是地址值. // 组一Integer i1=new I ...
- 配置Pouch镜像
镜像下载.域名解析.时间同步请点击阿里云开源镜像站 一.pouch镜像简介 阿里巴巴正式开源了基于Apache 2.0协议的容器技术Pouch.Pouch是一款轻量级的容器技术,拥有快速高效.可移植性 ...
- python练习册 每天一个小程序 第0005题
1 # -*-coding:utf-8-*- 2 __author__ = 'Deen' 3 ''' 4 题目说明: 你有一个目录,装了很多照片,把它们的尺寸变成都不大于 iPhone5 分辨率的大小 ...
- 《前端运维》二、Nginx--3静态资源服务、跨域与其他
一.静态资源服务 首先,静态资源一般是指客户端发送请求到Web服务器,web服务器从内存中取得相应的文件,返回给客户端,客户端解析并渲染出来.动态资源呢,则是由客户端发起请求,先交由web容器,web ...