jQuery代码
1 | $.ajax({ |
1 | $.ajax({ |
使用方法
1 | var checkNum = /^[A-Za-z0-9]+$/; |
1.非负整数 /^/d+$/
2.正整数 /^[0-9][1-9][0-9]$/
3.非正整数 /^((-/d+)|(0+))$/
4.负整数 /^-[0-9][1-9][0-9]$/
5.整数 /^-?/d+$/
6.非负浮点数 /^/d+(/./d+)?$/
7.正浮点数 /^(([0-9]+/.[0-9][1-9][0-9])|([0-9][1-9][0-9]/.[0-9]+)|([0-9][1-9][0-9]))$/
8.非正浮点数 /^((-/d+(/./d+)?)|(0+(/.0+)?))$/
9.负浮点数 /^(-(([0-9]+/.[0-9][1-9][0-9])|([0-9][1-9][0-9]/.[0-9]+)|([0-9][1-9][0-9])))$/
10.浮点数 /^(-?/d+)(/./d+)?$/
11.数字 /^/d+(/.{1}/d+)?$/
12.由26个英文字母组成的字符串 /^[A-Za-z]+$/
13.由26个英文字母的大写组成的字符串 /^[A-Z]+$/
14.由26个英文字母的小写组成的字符串 /^[a-z]+$/
15.由数字和26个英文字母组成的字符串 /^[A-Za-z0-9]+$/
16.由数字、26个英文字母或者下划线组成的字符串 /^/w+$/
17.匹配所有单字节长度的字符组成的字符串 /^[/x00-/xff]+$/
18.匹配所有双字节长度的字符组成的字符串 /^[^/x00-/xff]+$/
19.字符串是否含有双字节字 /[^/x00-/xff]+/
20.email地址 /^[/w-]+(/.[/w-]+)*@[/w-]+(/.[/w-]+)+$/
或者 /w+([-+.]w+)@w+([-.]w+).w+([-.]w+)*/
21.url地址 /^[a-zA-z]+://(/w+(-/w+))(/.(/w+(-/w+)))(/?/S)?$/
或者 /http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?/
22.匹配中文字符的正则 /[u4e00-u9fa5]/
23.匹配双字节字符(包括汉字在内) /[^x00-xff]/
应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
1 |
|
24.匹配空行的正则 /n[s| ]*r/
25.匹配HTML标记的正则 /<(.)>.</1>|<(.*) />/
26.匹配首尾空格的正则 /(^s*)|(s*$)/
应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:
1 | String.prototype.trim = function(){ |
27.匹配IP地址的正则 /(d+).(d+).(d+).(d+)/
应用:利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:
1 | function IP2V(ip){ |
其实直接用split函数来分解可能更简单,程序如下:
1 | var ip=”10.100.20.168″; |
28.去除字串中重复的字符的javascript程序
1 | var s=”abacabefgeeii”; |
/*使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,
两者串连。这个方法对于字符顺序有要求的字符串可能不适用。*/
29.用正则表达式从URL地址中提取文件名的javascript程序
1 | s=”http://www.9499.net/page1.htm“; |
30.限制表单文本框输入内容
只能输入中文:
onkeyup=”value=value.replace(/[^u4E00-u9FA5]/g,”)”
onbeforepaste=”clipboardData.setData(‘text’,
clipboardData.getData(‘text’).replace(/[^u4E00-u9FA5]/g,”))”
只能输入全角字符:
onkeyup=”value=value.replace(/[^uFF00-uFFFF]/g,”)”
onbeforepaste=”clipboardData.setData(‘text’,
clipboardData.getData(‘text’).replace(/[^uFF00-uFFFF]/g,”))”
只能输入数字:
onkeyup=”value=value.replace(/[^d]/g,”)”
onbeforepaste=”clipboardData.setData(‘text’,
clipboardData.getData(‘text’).replace(/[^d]/g,”))”
只能输入数字和英文:
onkeyup=”value=value.replace(/[W]/g,”)”
onbeforepaste=”clipboardData.setData(‘text’,
clipboardData.getData(‘text’).replace(/[^d]/g,”))”
31.验证文件名由字母,数字,下滑线组成 /^((/w+)(/.{1})(/w+))$/
32.匹配日期(1900-1999)
/^19/d{2}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1])))$/
33.匹配日期(2000-2999)
/^20/d{2}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1])))$/
34.匹配日期时间
/^(1|2/d{3}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1]))))( (/d{2}):(/d{2}):(/d{2}))?$/
1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> |
经本人整理后正确能够运行的版本, 网上好多去掉内容,或是故意写错的版本,此处代码为修正代码,复制到文本编辑器内,保存成html格式即可运行。
为了保证自己辛苦写的javascript代码不被直接copy走,很多人都想对自己的javascript代码进行加密处理
使用以下代码可以完美的进行加密处理。
直接上javascript代码
基本上实现对普通js进行压缩加密解密的过程。
为了实现网页更快速的展示,通常需要将CSS文件进行压缩整理。
根据网上一些Javascript教程,我编写了一个网页代码可以实现CSS的压缩整理,直接上代码
1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> |
javascript实现的样式表(CSS) 格式整理与压缩,可以分为多行与单行,非常不错。
(function(){})()
相当于先定义 function xx(){},后调用 xx();
()是最高优先级的,所以先执行function(){},
这个定义了一个匿名函数,等于xx=function(){}
接着就是调用xx()了;
给个例子
JScript code
1 | functionf1(a) |
1 | $.getScript('xxx.js',function(){ |
应该是jquery的监听问题,ajax成功后append进来的数据不会被原先已经定义好的函数识别。对于这种情况,我一般采用将所有jquery函数归入一个函数中,然后在ajax的success函数内部调用这个函数,以识别新增数据。示例:
1 | $(document).ready(function(){ |
URL即统一资源定位符 (Uniform Resource Locator, URL),完整的URL由这几个部分构成:
1 | scheme://host:port/path?query#fragment |
scheme:通信协议,常用的http,ftp,maito等。
host:主机,服务器(计算机)域名系统 (DNS) 主机名或 IP 地址。
port:端口号,整数,可选,省略时使用方案的默认端口,如http的默认端口为80。
path:路径,由零或多个”/“符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。
query:查询,可选,用于给动态网页(如使用CGI、ISAPI、PHP/JSP/ASP/ASP.NET等技术制作的网页)传递参数,可有多个参数,用”&”符号隔开,每个参数的名和值用”=”符号隔开。
fragment:信息片断,字符串,用于指定网络资源中的片断。例如一个网页中有多个名词解释,可使用fragment直接定位到某一名词解释。(也称为锚点)
下面我们举例一个URL,然后获得它的各个组成部分。
http://www.ttwinbug.com/newsDetail.php?id=65
window.location.href
可以获得整个URL字符串(在浏览器中就是完整的地址栏)。
1 | var test = window.location.href; |
1)算法简介
插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。
2)算法描述和实现
一般来说,插入排序都采用in-place在数组上实现。具体算法描述如下:
从第一个元素开始,该元素可以认为已经被排序;
取出下一个元素,在已经排序的元素序列中从后向前扫描;
如果该元素(已排序)大于新元素,将该元素移到下一位置;
重复步骤3,直到找到已排序的元素小于或者等于新元素的位置;
将新元素插入到该位置后;
重复步骤2~5。
JavaScript代码实现:
1 | function insertionSort(array){ |
shift:删除原数组第一项,并返回删除元素的值;如果数组为空则返回undefined
1 | var a = [1,2,3,4,5]; |
unshift:将参数添加到原数组开头,并返回数组的长度
1 | var a = [1,2,3,4,5]; |