1.数组去重

// 思路:获取没重复的最右一值放入新数组
/*
* 推荐的方法
*
* 方法的实现代码相当酷炫,
* 实现思路:获取没重复的最右一值放入新数组。
* (检测到有重复值时终止当前循环同时进入顶层循环的下一轮判断)*/
function uniq(array){
var temp = [];
var index = [];
var l = array.length;
for(var i = 0; i < l; i++) {
for(var j = i + 1; j < l; j++){
if (array[i] === array[j]){
i++;
j = i;
}
}
temp.push(array[i]);
index.push(i);
}
console.log(index);
return temp;
}

2.常用很正则校验

//校验输入内容
function clearNoNum(obj) {
//先把非数字的都替换掉,除了数字和.
obj.value = obj.value.replace(/[^\d.]/g, "");
//保证只有出现一个.而没有多个.
obj.value = obj.value.replace(/\.{2,}/g, ".");
//必须保证第一个为数字而不是.
obj.value = obj.value.replace(/^\./g, "");
//保证.只出现一次,而不能出现两次以上
obj.value = obj.value.replace(".", "$#$").replace(/\./g, "").replace("$#$", ".");
//只能输入两个小数
obj.value = obj.value.replace(/^(\-)*(\d+)\.(\d\d).*$/, '$1$2.$3');
//只能输入0~100
obj.value = onj.value.replace(/^((?!0)\d{1,2}|100)$/,"");
}

3.将long形式的时间转化为格式化日期

//前台获取后台后台传来的日期格式会自动转化为long数字类型,需要在前台对数字类型进行格式化
//模板代码 仅供参考
Date.prototype.format = function(f){
var o ={
"M+" : this.getMonth()+1, //month
"d+" : this.getDate(), //day
"h+" : this.getHours(), //hour
"m+" : this.getMinutes(), //minute
"s+" : this.getSeconds(), //second
"q+" : Math.floor((this.getMonth()+3) /3), //quarter
"S" : this.getMilliseconds() //millisecond
}
if(/(y+)/.test(f))f=f.replace(RegExp.$1,(this.getFullYear()+"").substr(4 - RegExp.$1.length));
for(var k in o)
if(new RegExp("("+ k +")").test(f))f = f.replace(RegExp.$1,RegExp.$1.length==1 ? o[k] : ("00"+ o[k]).substr((""+ o[k]).length));return f
} var t=1347497754133;
var d= new Date();
d.setTime(t);
var s=d.format('yyyy-MM-dd hh:mm:ss');
alert(s);

4.后台对json特殊符号的转义

/**
* 转换特殊字符,将json串转换为JS能直接识别的json
* json中如果含有单引号 或者特殊字符,前台json.parse()函数在解析时会报错
* 因此需要在后台进行转义
* @param oldJson
* @return
*/
public static String getJsonForJS(String oldJson) {
String newJson = oldJson;
newJson = newJson.replaceAll("\\\\", "\\\\\\\\");
newJson = newJson.replaceAll("\\'", "\\\\'");
newJson = newJson.replaceAll("\\\"", "\\\\\"");
return newJson;
}

5.js兼容性的页面关闭方式

//新版本谷歌和火狐的兼容性关闭方法
//场景:如果存在父页面window.close()有效
//如果没有父页面直接window.close()就会出现Scripts may close only the windows that were opened by it.导致页面点击无反应
function cancle() {
var userAgent = navigator.userAgent;
if (userAgent.indexOf("Firefox") != -1 || userAgent.indexOf("Chrome") != -1) {
if(window.opener == null) {
window.location.href = "about:blank";
} else {
window.close();
}
} else {
window.opener = null;
window.open("", "_self");
window.close();
}
}

6.my97datapicker日期间隔设置

//最好使用WdatePicker提供的表达式去计算,自行计算然后使用字符串设置回出现问题
//时间间隔控制在30天之间
WdatePicker({
readOnly: 'true',
dateFmt: 'yyyy-MM-dd',
onclearing: function () {
showAlert("日期必须被选择。");
return true;
},
maxDate: '#F{$dp.$D(\'endTime\')}',
minDate: '#F{$dp.$D(\'endTime\',{d:-29})}'
})
WdatePicker({
readOnly: 'true',
dateFmt: 'yyyy-MM-dd',
onclearing: function () {
showAlert("日期必须被选择。");
return true;
},
minDate: '#F{$dp.$D(\'startTime\')}',
maxDate: '#F{$dp.$D(\'startTime\',{d:29})}'
})
//月份间隔控制在11个月之间
WdatePicker({
readOnly: 'true',
dateFmt: 'yyyy-MM',
onclearing: function () {
showAlert("日期必须被选择。");
return true;
},
maxDate: '#F{$dp.$D(\'endTime\')}',
minDate: '#F{$dp.$D(\'endTime\',{d:-11})}'
})
WdatePicker({
readOnly: 'true',
dateFmt: 'yyyy-MM',
onclearing: function () {
showAlert("日期必须被选择。");
return true;
},
minDate: '#F{$dp.$D(\'startTime\')}',
maxDate: '#F{$dp.$D(\'startTime\',{d:11})}'
})

7.虚拟机设置

-server -XX:PermSize=128M -XX:MaxPermSize=128M

8.js判断数组中是否有重复数据

function isRepeat(arr) {
var hash = {};
for(var i in arr) {
if(hash[arr[i]]) {
return true;
}
hash[arr[i]] = true;
}
return false;
}

js常用方法集合的更多相关文章

  1. (2)Underscore.js常用方法

    目录 1.集合相关方法        1.1.数组的处理                map(循环,有返回值),将返回的值依次存入一个新的数组                each(循环,无返回值 ...

  2. js算法集合(一) 水仙花数 及拓展(自幂数的判断)

    js算法集合(一) ★ 最近有些朋友跟我说对js中的一些算法感到很迷惑,知道这个算法到底是怎么回事,但是就是不会用代码把它写出来,这里我跟大家分享一下做水仙花数的算法的思路,并对其扩展到自幂数的算法, ...

  3. js算法集合(二) javascript实现斐波那契数列 (兔子数列)

    js算法集合(二)  斐波那契数列 ★ 上一次我跟大家分享一下做水仙花数的算法的思路,并对其扩展到自幂数的算法,这次,我们来对斐波那契数列进行研究,来加深对循环的理解.     Javascript实 ...

  4. js 遍历集合删除元素

    js 遍历集合删除元素 /** * 有效的方式 - 改变下标,控制遍历 */ for (var i = 0; i < arr.length; i++) { if (...) { arr.spli ...

  5. JS中集合对象(Array、Map、Set)及类数组对象的使用与对比

    原文地址 在使用js编程的时候,常常会用到集合对象,集合对象其实是一种泛型,在js中没有明确的规定其内元素的类型,但在强类型语言譬如Java中泛型强制要求指定类型. ES6引入了iterable类型, ...

  6. js library 集合

    js library 集合 查看已经开源的js library https://cdnjs.com/

  7. js常用方法和检查是否有特殊字符串和倒序截取字符串

     js常用方法demo <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...

  8. 数据结构与算法 --- js描述集合

    js描述集合 function Set(){ this.datasource=[]; this.add=add; this.remove=remove; //this.size=size; //thi ...

  9. JS 数组,对象常用方法 集合

    数组 1.数组去重:   主要是使用的 new Set() 方法     https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Referen ...

随机推荐

  1. 学习Spring5必知必会(4)~使用注解配置、使用java代码配置

    ● 注意:使用注解并不能完全取代xml配置,比如配置连接池DruidDataSource,我们就不能到这个类中去贴注解. 想要实现零配置(完全不使用xml进行配置):javaConfig + 注解 ● ...

  2. (二)scrapy 中如何自定义 pipeline 下载图片

    这里以一个很简单的小爬虫为例,爬取 壹心理 网站的阅读页面第一页的所有文章及其对应的图片,文章页面如下: 创建项目 首先新建一个 scrapy 项目,安装好相关依赖(步骤可参考:scrapy 安装及新 ...

  3. virtualenv 创建隔离工作环境

    在开发 Python 应用程序的时候,每个项目所需要的python版本和各种包依赖都可能不完全一样,我们当然希望当前运行环境只包含对当前项目有用的包依赖,以保证运行环境的干净.virtualenv就是 ...

  4. 对于计算正确率时 logits.argmax(dim=1),torch.eq(pre_label,label)

    额  好像是一句非常简单的代码 ,但是作为新手 ,我是完全看不懂哎 前十眼. 首先 这里的logits是一个 (a,b)维的张量.其中a是你的全连接输出维度,b是一个batch中的样本数量. 我们经过 ...

  5. BI数据可视化工具怎么选?用这款就够了!

    任何一项产品的选择都需要谨慎而全面,BI数据可视化工具的选择就更不用说了.作为企业的IT部门,如果没有良好的BI工具支持,IT部门将会十分容易陷入困境.那么面对多元化的BI工具市场,IT部门该如何选择 ...

  6. 财务数据分析工具的选择:Excel还是大数据BI?

    ​财务数据分析一般都采用什么工具?跟财务数据分析的哪些指标有关?要怎样展现财务数据间的紧密关联? 财务报表分析比较复杂,一般来说主要包括以下项目: 1. 趋势:在多个时间段内为财务报表中的关键项目创建 ...

  7. N种排序算法

    本文根据<算法(第4版)>和<算法图解>整理.文中代码使用python编写. (一)选择排序 每次遍历整个数组,选出其中最小值.如果数组长度为n,则需要(n-1)+(n-2)+ ...

  8. LeetCode-079-单词搜索

    单词搜索 题目描述:给定一个 m x n 二维字符网格 board 和一个字符串单词 word .如果 word 存在于网格中,返回 true :否则,返回 false . 单词必须按照字母顺序,通过 ...

  9. php jsonp接口

    //jsonp回调 $callback = isset($_GET['callback']) ? trim($_GET['callback']) : ''; //jsonp回调参数,必需 $cgc_k ...

  10. zabbix5.0监控mysql

    最近开发让对mysql数据库进行监控,由于公司的开发大部分都是以WINDOWS环境下运行的,只有少部分是在LINUX下.我自己先在linux做了一个测试.按照网上教程折腾了三天.最后看着官方教程很轻松 ...