不能错过的js方法合集

var h = {};  
    h.get = function (url, data, ok, error) {  
        $.ajax({  
            url: url,  
            data: data,  
            dataType: ‘json‘,  
            success: ok,  
            error: error  
        });  
    }  
    h.post = function (url, data, ok, error) {  
        $.ajax({  
            url: url,  
            data: data,  
            type: ‘post‘,  
            dataType: ‘json‘,  
            success: ok,  
            error: error  
        });  
    }  
    //获取url参数  
    h.url = function (url) {  
        if (!url) {  
            url = location.search.substring(1);  
        } else {  
            url = url.substr(url.indexOf(‘?‘) + 1);  
        }  
        var args = new Object();   // 声明并初始化一个 "类"  
        // 获得地址(URL)"?"后面的字符串.  
        var query = decodeURI(url);  
        var pairs = query.split("&");  // 分割URL(别忘了‘&‘是用来连接下一个参数)  
        for (var i = 0; i < pairs.length; i++) {  
            var pos = pairs[i].indexOf(‘=‘);  
            if (pos == -1) continue; // 它在找有等号的 数组[i]  
            var argname = pairs[i].substring(0, pos); // 参数名字  
            var value = pairs[i].substring(pos + 1);  // 参数值  
            // 以键值对的形式存放到"args"对象中  
            args[argname] = decodeURI(value);  
        }  
        return args;  
    }  
      
    // 返回字符串的实际长度, 一个汉字算2个长度   
    String.prototype.strlen = function () {  
        return this.replace(/[^\x00-\xff]/g, "**").length;  
    }  
    //字符串超出省略  
    String.prototype.cutstr = function (len) {  
        var restr = this;  
        var wlength = this.replace(/[^\x00-\xff]/g, "**").length;  
        if (wlength > len) {  
            for (var k = len / 2; k < this.length; k++) {  
                if (this.substr(0, k).replace(/[^\x00-\xff]/g, "**").length >= len) {  
                    restr = this.substr(0, k) + "...";  
                    break;  
                }  
            }  
        }  
        return restr;  
    }  
    //替换全部  
    String.prototype.replaceAll = function (s1, s2) {  
        return this.replace(new RegExp(s1, "gm"), s2)  
    }  
    //字符串去空格  
    String.prototype.trim = function () {  
        return this.replace(/(^\s*)|(\s*$)/g, "");  
    }  
    String.prototype.trimAll = function () {  
        return this.replace(/\s+/g, "");  
    }  
    String.prototype.lTrim = function () {  
        return this.replace(/(^\s*)/g, "");  
    }  
    String.prototype.rTrim = function () {  
        return this.replace(/(\s*$)/g, "");  
    }  
    //判断是否以某个字符串开头  
    String.prototype.startWith = function (s) {  
        return this.indexOf(s) == 0  
    }  
    //判断是否以某个字符串结束  
    String.prototype.endWith = function (s) {  
        var d = this.length - s.length;  
        return (d >= 0 && this.lastIndexOf(s) == d)  
    }  
      
    //删除数组中存在重复的元素  
    function getUnique(someArray) {  
        tempArray = someArray.slice(0); //复制数组到临时数组  
        for (var i = 0; i < tempArray.length; i++) {  
            for (var j = i + 1; j < tempArray.length;) {  
                if (tempArray[j] == tempArray[i])  
                    //后面的元素若和待比较的相同,则删除并计数;  
                    //删除后,后面的元素会自动提前,所以指针j不移动  
                {  
                    tempArray.splice(j, 1);  
                }  
                else {  
                    j++;  
                }  
                //不同,则指针移动  
            }  
        }  
        return tempArray;  
    }  
    //判断数组中是否存在重复的元素  
    function confirmRepeat(someArray) {  
        tempArray = someArray.slice(0); //复制数组到临时数组  
        for (var i = 0; i < tempArray.length; i++) {  
            for (var j = i + 1; j < tempArray.length;) {  
                if (tempArray[j] == tempArray[i])  
                    //后面的元素若和待比较的相同,则删除并计数;  
                    //删除后,后面的元素会自动提前,所以指针j不移动  
                {  
                    return true;  
                }  
                else {  
                    j++;  
                }  
                //不同,则指针移动  
            }  
        }  
        return false;  
    }  
      
    //判断某个值是否在数组中  
    Array.prototype.in_array = function (e) {  
        for (i = 0; i < this.length; i++) {  
            if (this[i] == e)  
                return true;  
        }  
        return false;  
    }  
    //判断某个值在数组中的位置  
    Array.prototype.indexOf = function (e) {  
        for (i = 0; i < this.length; i++) {  
            if (this[i] == e)  
                return i;  
        }  
        return -1;  
    }  
      
    //转义html标签  
    function HtmlEncode(text) {  
        return text.replace(/&/g, ‘&‘).replace(/\"/g, ‘"‘).replace(/</g, ‘<‘).replace(/>/g, ‘>‘)  
    }  
      
    //格式化日期 DateFormat(‘yyyy_MM_dd hh:mm:ss:SS 星期w 第q季度‘)  
    function DateFormat(format, date) {  
        if (!date) {  
            date = new Date();  
        }  
        var Week = [‘日‘, ‘一‘, ‘二‘, ‘三‘, ‘四‘, ‘五‘, ‘六‘];  
        var o = {  
            "y+": date.getYear(), //year  
            "M+": date.getMonth() + 1, //month   
            "d+": date.getDate(), //day   
            "h+": date.getHours(), //hour   
            "H+": date.getHours(), //hour  
            "m+": date.getMinutes(), //minute   
            "s+": date.getSeconds(), //second   
            "q+": Math.floor((date.getMonth() + 3) / 3), //quarter   
            "S": date.getMilliseconds(), //millisecond   
            "w": Week[date.getDay()]  
        }  
        if (/(y+)/.test(format)) {  
            format = format.replace(RegExp.$1, (date.getFullYear() + "").substr(4 - RegExp.$1.length));  
        }  
        for (var k in o) {  
            if (new RegExp("(" + k + ")").test(format)) {  
                format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));  
            }  
        }  
        return format;  
    }  
      
    //设置cookie值  
    function setCookie(name, value, Hours) {  
        var d = new Date();  
        var offset = 8;  
        var utc = d.getTime() + (d.getTimezoneOffset() * 60000);  
        var nd = utc + (3600000 * offset);  
        var exp = new Date(nd);  
        exp.setTime(exp.getTime() + Hours * 60 * 60 * 1000);  
        document.cookie = name + "=" + escape(value) + ";path=/;expires=" + exp.toGMTString() + ";domain=360doc.com;"  
    }  
    //获取cookie值  
    function getCookie(name) {  
        var arr = document.cookie.match(new RegExp("(^| )" + name + "=([^;]*)(;|$)"));  
        if (arr != null) return unescape(arr[2]);  
        return null  
    }  
      
    //加入收藏夹  
    function AddFavorite(sURL, sTitle) {  
        try {  
            window.external.addFavorite(sURL, sTitle)  
        } catch (e) {  
            try {  
                window.sidebar.addPanel(sTitle, sURL, "")  
            } catch (e) {  
                alert("加入收藏失败,请使用Ctrl+D进行添加")  
            }  
        }  
    }  
    //设为首页  
    function setHomepage(homeurl) {  
        if (document.all) {  
            document.body.style.behavior = ‘url(#default#homepage)‘;  
            document.body.setHomePage(homeurl)  
        } else if (window.sidebar) {  
            if (window.netscape) {  
                try {  
                    netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect")  
                } catch (e) {  
                    alert("该操作被浏览器拒绝,如果想启用该功能,请在地址栏内输入about:config,然后将项 signed.applets.codebase_principal_support 值该为true");  
                }  
            }  
            var prefs = Components.classes[‘@mozilla.org/preferences-service;1‘].getService(Components.interfaces.nsIPrefBranch);  
            prefs.setCharPref(‘browser.startup.homepage‘, homeurl)  
        }  
    }  
      
    //跨浏览器绑定事件  
    function addEventSamp(obj, evt, fn) {  
        if (!oTarget) { return; }  
        if (obj.addEventListener) {  
            obj.addEventListener(evt, fn, false);  
        } else if (obj.attachEvent) {  
            obj.attachEvent(‘on‘ + evt, fn);  
        } else {  
            oTarget["on" + sEvtType] = fn;  
        }  
    }  
    //跨浏览器删除事件  
    function delEvt(obj, evt, fn) {  
        if (!obj) { return; }  
        if (obj.addEventListener) {  
            obj.addEventListener(evt, fn, false);  
        } else if (oTarget.attachEvent) {  
            obj.attachEvent("on" + evt, fn);  
        } else {  
            obj["on" + evt] = fn;  
        }  
    }  
      
    //判断是否移动设备访问  
    function isMobileUserAgent() {  
        return (/iphone|ipod|android.*mobile|windows.*phone|blackberry.*mobile/i.test(window.navigator.userAgent.toLowerCase()));  
    }  
      
    //完美判断是否为网址  
    function IsURL(strUrl) {  
        var regular = /^\b(((https?|ftp):\/\/)?[-a-z0-9]+(\.[-a-z0-9]+)*\.(?:com|edu|gov|int|mil|net|org|biz|info|name|museum|asia|coop|aero|[a-z][a-z]|((25[0-5])|(2[0-4]\d)|(1\d\d)|([1-9]\d)|\d))\b(\/[-a-z0-9_:\@&?=+,.!\/~%\$]*)?)$/i  
        if (regular.test(strUrl)) {  
            return true;  
        } else {  
            return false;  
        }  
    }  
      
    //获取页面高度  
    function getPageHeight() {  
        var g = document, a = g.body, f = g.documentElement, d = g.compatMode == "BackCompat" ? a : g.documentElement;  
        return Math.max(f.scrollHeight, a.scrollHeight, d.clientHeight);  
    }  
    //获取页面宽度  
    function getPageWidth() {  
        var g = document, a = g.body, f = g.documentElement, d = g.compatMode == "BackCompat" ? a : g.documentElement;  
        return Math.max(f.scrollWidth, a.scrollWidth, d.clientWidth);  
    }  
      
    //获取页面可视宽度  
    function getPageViewWidth() {  
        var d = document, a = d.compatMode == "BackCompat"  
                        ? d.body  
                        : d.documentElement;  
        return a.clientWidth;  
    }  
    //获取页面可视高度  
    function getPageViewHeight() {  
        var d = document, a = d.compatMode == "BackCompat"  
                        ? d.body  
                        : d.documentElement;  
        return a.clientHeight;  
    }  
      
    //获取页面scrollLeft  
    function getPageScrollLeft() {  
        var a = document;  
        return a.documentElement.scrollLeft || a.body.scrollLeft;  
    }  
    //获取页面scrollTop  
    function getPageScrollTop() {  
        var a = document;  
        return a.documentElement.scrollTop || a.body.scrollTop;  
    }  
    //获取窗体可见范围的宽与高  
    function getViewSize() {  
        var de = document.documentElement;  
        var db = document.body;  
        var viewW = de.clientWidth == 0 ? db.clientWidth : de.clientWidth;  
        var viewH = de.clientHeight == 0 ? db.clientHeight : de.clientHeight;  
        return Array(viewW, viewH);  
    }  
    //随机数时间戳  
    function uniqueId() {  
        var a = Math.random, b = parseInt;  
        return Number(new Date()).toString() + b(10 * a()) + b(10 * a()) + b(10 * a());  
    }  
      
    //获取网页被卷去的位置  
    function getScrollXY() {  
        return document.body.scrollTop ? {  
            x: document.body.scrollLeft,  
            y: document.body.scrollTop  
        } : {  
            x: document.documentElement.scrollLeft,  
            y: document.documentElement.scrollTop  
        }  
    }  
      
    //匹配国内电话号码(0511-4405222 或 021-87888822)   
    function istell(str) {  
        var result = str.match(/\d{3}-\d{8}|\d{4}-\d{7}/);  
        if (result == null) return false;  
        return true;  
    }  
    //匹配身份证(15位或18位)   
    function isidcard(str) {  
        var result = str.match(/\d{15}|\d{18}/);  
        if (result == null) return false;  
        return true;  
    }  
    //移动电话  
    function checkMobile(str) {  
        if (!(/^1[3|5|8][0-9]\d{4,8}$/.test(str))) {  
            return false;  
        }  
        return true;  
    }  
    // 判断输入是否是一个由 0-9 / A-Z / a-z 组成的字符串   
    function isalphanumber(str) {  
        var result = str.match(/^[a-zA-Z0-9]+$/);  
        if (result == null) return false;  
        return true;  
    }  
    // 判断输入是否是有效的电子邮件   
    function isemail(str) {  
        var result = str.match(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/);  
        if (result == null) return false;  
        return true;  
    }  
      
    //金额大写转换函数 transform(‘123431233132.23‘)  
    function transform(tranvalue) {  
        try {  
            var i = 1;  
            var dw2 = new Array("", "万", "亿"); //大单位  
            var dw1 = new Array("拾", "佰", "仟"); //小单位  
            var dw = new Array("零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"); //整数部分用  
            //以下是小写转换成大写显示在合计大写的文本框中       
            //分离整数与小数  
            var source = splits(tranvalue);  
            var num = source[0];  
            var dig = source[1];  
            //转换整数部分  
            var k1 = 0; //计小单位  
            var k2 = 0; //计大单位  
            var sum = 0;  
            var str = "";  
            var len = source[0].length; //整数的长度  
            for (i = 1; i <= len; i++) {  
                var n = source[0].charAt(len - i); //取得某个位数上的数字  
                var bn = 0;  
                if (len - i - 1 >= 0) {  
                    bn = source[0].charAt(len - i - 1); //取得某个位数前一位上的数字  
                }  
                sum = sum + Number(n);  
                if (sum != 0) {  
                    str = dw[Number(n)].concat(str); //取得该数字对应的大写数字,并插入到str字符串的前面  
                    if (n == ‘0‘) sum = 0;  
                }  
                if (len - i - 1 >= 0) { //在数字范围内  
                    if (k1 != 3) { //加小单位  
                        if (bn != 0) {  
                            str = dw1[k1].concat(str);  
                        }  
                        k1++;  
                    } else { //不加小单位,加大单位  
                        k1 = 0;  
                        var temp = str.charAt(0);  
                        if (temp == "万" || temp == "亿") //若大单位前没有数字则舍去大单位  
                            str = str.substr(1, str.length - 1);  
                        str = dw2[k2].concat(str);  
                        sum = 0;  
                    }  
                }  
                if (k1 == 3) { //小单位到千则大单位进一  
                    k2++;  
                }  
            }  
            //转换小数部分  
            var strdig = "";  
            if (dig != "") {  
                var n = dig.charAt(0);  
                if (n != 0) {  
                    strdig += dw[Number(n)] + "角"; //加数字  
                }  
                var n = dig.charAt(1);  
                if (n != 0) {  
                    strdig += dw[Number(n)] + "分"; //加数字  
                }  
            }  
            str += "元" + strdig;  
        } catch (e) {  
            return "0元";  
        }  
        return str;  
    }  
    //拆分整数与小数  
    function splits(tranvalue) {  
        var value = new Array(‘‘, ‘‘);  
        temp = tranvalue.split(".");  
        for (var i = 0; i < temp.length; i++) {  
            value = temp;  
        }  
        return value;  
    }  
      
    //格式化数字  
    function number_format(number, decimals, dec_point, thousands_sep) {  
        /* 
        * 参数说明: 
        * number:要格式化的数字 
        * decimals:保留几位小数 
        * dec_point:小数点符号 
        * thousands_sep:千分位符号 
        * */  
        number = (number + ‘‘).replace(/[^0-9+-Ee.]/g, ‘‘);  
        var n = !isFinite(+number) ? 0 : +number,  
            prec = !isFinite(+decimals) ? 0 : Math.abs(decimals),  
            sep = (typeof thousands_sep === ‘undefined‘) ? ‘,‘ : thousands_sep,  
            dec = (typeof dec_point === ‘undefined‘) ? ‘.‘ : dec_point,  
            s = ‘‘,  
            toFixedFix = function (n, prec) {  
                var k = Math.pow(10, prec);  
                return ‘‘ + Math.ceil(n * k) / k;  
            };  
      
        s = (prec ? toFixedFix(n, prec) : ‘‘ + Math.round(n)).split(‘.‘);  
        var re = /(-?\d+)(\d{3})/;  
        while (re.test(s[0])) {  
            s[0] = s[0].replace(re, "$1" + sep + "$2");  
        }  
      
        if ((s[1] || ‘‘).length < prec) {  
            s[1] = s[1] || ‘‘;  
            s[1] += new Array(prec - s[1].length + 1).join(‘0‘);  
        }  
        return s.join(dec);  
    }

时间: 2024-10-11 06:40:02

不能错过的js方法合集的相关文章

移动端适配方法合集

转自: http://azq.space/blog/bigcan-lesson-1/ 1.简单粗暴型 zoom方式: <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0"><!--必须,放在head标签中--> <script> var _SCALE_ = 1; _SCA

Vs2015 win10虚拟机启动问题:无法设置UDP端口 解决方法 合集(转载)

刚装的vs2015 社区版 出现这个问题,wp8.1和win10m模拟器都无法启动,找了好久找到的解决方案,放这儿供大家参考,免得大家像我一样走弯路: Windows Phone emulator not starting (couldn`t setup the UDP port) After updating Windows 10 to build 10061 windows phone emulators (all 8.1 and 10) stopped starting. I get th

Unity3D 角色(物体) 移动方法 合集

1. 简介 在Unity3D中,有多种方式可以改变物体的坐标,实现移动的目的,其本质是每帧修改物体的position. 2. 通过Transform组件移动物体 Transform 组件用于描述物体在空间中的状态,它包括 位置(position), 旋转(rotation)和 缩放(scale). 其实所有的移动都会导致position的改变,这里所说的通过Transform组件来移动物体,指的是直接操作Transform来控制物体的位置(position). 2.1 Transform.Tra

Android中解析JSON格式数据常见方法合集

待解析的JSON格式的文件如下: [{"id":"5", "version":"1.0", "name":"xiaowang"}, {"id":"10", "version":"2.0", "name":"lisi"}] 一.使用JSONObject来解析JSON数据

前端开发常用原生JS API合集

一.节点 1.1 节点属性 Node.nodeName //返回节点名称,只读 Node.nodeType //返回节点类型的常数值,只读 Node.nodeValue //返回Text或Comment节点的文本值,只读 Node.textContent //返回当前节点和它的所有后代节点的文本内容,可读写 Node.baseURI //返回当前网页的绝对路径 Node.ownerDocument //返回当前节点所在的顶层文档对象,即document Node.nextSibling //返回

菜鸟的Xamarin.Forms前行之路——各种报错问题解决方法合集(不定时更新)

2017-08-24 1序列不包含任何元素 这个是布局方面的问题,请检查布局是否出现问题 2一个或多个项目目标不支持生成操作"EmbeddedResource" 换成管理员方式打开VS 3错误与XamalcTask或xamlFilePathAttribute有关 重新以管理员方式打开vs或者检查Xaml.Forms的Nuget包是否有更新,更新即可 [email protected](content) build action is supported 修改安卓项目的Androidma

原生 JS 中对象相关 API 合集

https://juejin.im/entry/58f8a705a0bb9f0065a4cb20 原文链接:https://microzz.com/2017/04/20/jsobject/ 原生 JavaScript 中对象相关 API 合集 - 对象篇.现在 jQuery 已经没有那么有优势了,原生 JS 赶紧学起来... -- 由microzz分享 Microzz [email protected] 主页 文章 标签 GitHub 关于我 掘金专栏 SegmentFault Vue音乐播放器

js验证网址等Javascript常见验证代码合集

发一个利用js验证网址是否正确,email格式是否正确,是否为数字及数字的范围,密码或字符长度及是否相等及要求的最小字符串长度,输入是否为空等Javascript常见验证代码合集,用的上的朋友可以拿去了自行添加整理. 关键的JavaScript代码函数: 查看代码 打印 001 /** 002 * 数据验证框架.增加了对id字段检查出错时,直接在对应后面添加一< span>元素来显示错误信息. 003 * 004 * @author www.phpernote.com 005 * @versi

python字符串操作实方法大合集

python字符串操作实方法大合集,包括了几乎所有常用的python字符串操作,如字符串的替换.删除.截取.复制.连接.比较.查找.分割等,需要的朋友可以参考下: #1.去空格及特殊符号 s.strip().lstrip().rstrip(',') #2.复制字符串 #strcpy(sStr1,sStr2) sStr1 = 'strcpy' sStr2 = sStr1 sStr1 = 'strcpy2' print sStr2 #3.连接字符串 #strcat(sStr1,sStr2) sStr