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 ...
随机推荐
- 快速构建 React 开发环境
使用 create-react-app 快速构建 React 开发环境 create-react-app 是来自于 Facebook,通过该命令我们无需配置就能快速构建 React 开发环境. cre ...
- 一、MarkDown学习笔记
MakrDown学习 MarkDown是什么? 是一种纯文件格式的标记语言,跟我们写txt和word是一样的,不过它有一些简单的标记,可以使普通文本具有一定的格式. MarkDown有什么样式? 样式 ...
- tep完整教程帮你突破pytest
持续维护的教程 tep教程会随着版本更新或经验积累,持续维护在电子书中,最新的最全的内容请锁定这篇文章[最新]tep完整教程帮你突破pytest: https://dongfanger.gitee.i ...
- PHP动态修改配置文件
文件结构: index.php 主页 config 配置文件 doUpdate.php 修改功能页 index.php <html> <head> <title>修 ...
- 【漏洞复现】Paraluni 安全事件分析及复现
Paraluni 被黑分析 前言 Paraluni (平行宇宙)是新加坡 Parallel Universe 基金会发布的一个 基于币安智能链的 DeFi 项目,更多相关内容见此处.在 2022 年 ...
- 理解并手写 call() 函数
手写自己的call,我们要先通过call的使用,了解都需要完成些什么功能? call()进行了调用,是个方法,已知是建立在原型上的,使用了多个参数(绑定的对象+传递的参数). 我们把手写的函数起名为m ...
- mybatis 基本配置 学习总结01
Mybatis 1.什么是Mybatis Mybatis是一款优秀的持久层框架. 几乎避免了所有JDBC代码和手动设置参数以及获取结果集的过程. Mybatis是一个半自动化的ORM框架(Object ...
- web自动化之selenium(一)
自动化搭建环境 1.自动搭建(一) #安装 pip install webdriver-helper 1.1示例 from webdriver_helper import * #get_webdriv ...
- RabbitMQ Go客户端教程4——路由
本文翻译自RabbitMQ官网的Go语言客户端系列教程,本文首发于我的个人博客:liwenzhou.com,教程共分为六篇,本文是第四篇--路由. 这些教程涵盖了使用RabbitMQ创建消息传递应用程 ...
- linux下安装简单的文件上传与下载工具 lrzsz
编译安装 1.从下面的网站下载 lrzsz-1.12.20.tar.gz wget https://ohse.de/uwe/releases/lrzsz-0.12.20.tar.gz 2.查看里面的I ...