js判断是否包含汉字和字母

网络真是个好东西,简直是要什么有什么,今天做项目时遇到了一个问题,有些字段的输入是要限制的,比如电话之类的字段,是不能有汉字和字符的,只可能是数字,所以今天在网上搜了一下,果然有此类代码,而且也挺全的。下面的这个函数就是 判断输入的值是否含有汉字或字符:

function checkFormat(str)
{
 if (escape(str).indexOf("%u")!=-1)
 alert("不能含有汉字");       
 else if(str.match(/\D/)!=null)
 {
  alert('不能含有字母');
 
}

其中,str是你在文本框中输入的值,传到此函数中,来进行判断。具体用法就是:

<input name="aa" type="text"οnblur="checkFormat(this.value)">

this.value即为你输入的值。当输完以后在别的地方点一下左键即可触发本函数来判断你是否输入了汉字或字符。另外,还可以在此函数上改进一下,再加一个参数用来显示哪个属性不能为空:

function checkFormat(str,name)
{
 if (escape(str).indexOf("%u")!=-1)
  if(name=='phone')

  {

    alert("电话不能含有汉字");

         
 else if(str.match(/\D/)!=null)
 {

    if(name=='phone')

    {


     alert('电话不能含有字母');

    }
 
}

如:<input name="aa" type="text"οnblur="checkFormat(this.value,'phone')">

就是说你输入的是电话的文本框,然后判断电话是不是有汉字或字符。



js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent

1、   传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。                           

例如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7& u='+encodeURIComponent("http://cang.baidu.com/bruce42")+'">退出</a& gt;');</script>

2、   进行url跳转时可以整体使用encodeURI

例如:Location.href=encodeURI("http://cang.baidu.com/do/s?word=百度&ct=21");

3、   js使用数据时可以使用escape

[Huoho.Com编辑]

例如:搜藏中history纪录。

4、   escape对0-255以外的unicode值进行编码时输出%u****格式,其它情况下escape,encodeURI,encodeURIComponent编码结果相同。
   最多使用的应为encodeURIComponent,它是将中文、韩文等特殊字符转换成utf-8格式的url编码,所以如果给后台传递参数需要使用encodeURIComponent时需要后台解码对utf-8支持(form中的编码方式和当前页面编码方式相同)

escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z

encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z

encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z

    escape(str) 方法,它用于转义不能用明文正确发送的任何字符。比如,电话号码中的空格将被转换成字符 %20,从而能够在 URL 中传递这些字符

如果需要发送安全信息或 XML,可能要考虑使用 send() 发送内容(本系列的后续文章中将讨论安全数据和 XML 消息)。如果不需要通过 send() 传递数据,则只要传递 null 作为该方法的参数即可。

js中的escape可以加密数据

我在用opener给前以页面传值的时候,遇到了数据被过滤的事情,好像是空格还是什么符号

被过滤了,想到了escape,好了,我就加密一下,传过去再解密



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值