美文网首页
2018-12-11

2018-12-11

作者: 11bbc2c5d0c6 | 来源:发表于2018-12-11 20:29 被阅读0次
正则
| <script type="text/javascript" src="[js/jquery-1.12.4.min.js](js/jquery-1.12.4.min.js)"></script> |
|  | <script type="text/javascript"> |
|  | //校验QQ |
|  | /* |
|  | //JS的方式比较麻烦 |
|  | function checkQQ(qq){ |
|  | var flag = true;//默认符合要求 |
|  | if(qq.length>=5 && qq.length<=15){ |
|  | if(qq.indexOf("0")){ |
|  | if(isNaN(qq)){ |
|  | flag = false;//不是数字 |
|  | } |
|  | }else{ |
|  | flag = false;//以0开头,不符合QQ标准 |
|  | } |
|  | }else{ |
|  | flag = false;//长度不符合 |
|  | } |
|  | return flag; |
|  | } |
|  | 
 |
|  | console.log(checkQQ("012345")); |
|  | console.log(checkQQ("a12b345")); |
|  | console.log(checkQQ("123456"));//true |
|  | console.log(checkQQ("1234567890987654321")); |
|  | */ |
|  | 
 |
|  | //正则匹配简单高效 |
|  | var regex = /^[1-9]\d{4,14}$/; |
|  |  |
|  | console.log(regex.test("012345")); |
|  | console.log(regex.test("a12b345")); |
|  | console.log(regex.test("123456"));//true |
|  | console.log(regex.test("1234567890987654321")); |
|  | </script> |
正则表达式
| <script type="text/javascript" src="[js/jquery-1.12.4.min.js](js/jquery-1.12.4.min.js)"></script> |
|  | <script type="text/javascript"> |
|  | //匹配字母a,i表示忽略大小写,g表示全文检索 |
|  | var re = new RegExp('a', 'ig'); |
|  | var re2 = /a/ig; |
|  | 
 |
|  | var str = 'abc'; |
|  | //调用test方法进行匹配,匹配成功返回true,否则返回false |
|  | // alert(re2.test(str));//true |
|  | 
 |
|  | //匹配字母ac,忽略大小写,全文检索 |
|  | re2 = /ac/ig; |
|  | // alert(re2.test(str));//false |
|  | 
 |
|  | //匹配数字 |
|  | var re3 = /\d/; |
|  | var str3 = '123'; |
|  | // alert(re3.test(str3));//true |
|  | 
 |
|  | str3 = '123ab1'; |
|  | // alert(re3.test(str3));//true |
|  | 
 |
|  | //匹配数字,全文检索 |
|  | re3 = /\d/g; |
|  | // alert(re3.test(str3));//true |
|  | 
 |
|  | //匹配数字开头并结尾 |
|  | re3 = /^\d$/; |
|  | // alert(re3.test(str3));//false |
|  | 
 |
|  | //匹配从开头到结尾有一个或多个数字 |
|  | re3 = /^\d+$/; |
|  | // alert(re3.test(str3));//false |
|  | 
 |
|  | //匹配数字、字母、下划线 |
|  | var re4 = /\w/; |
|  | var str4 = '@asd'; |
|  | // alert(re4.test(str4));//true |
|  | 
 |
|  | //匹配数字、字母、下划线开头 |
|  | re4 = /^\w/; |
|  | // alert(re4.test(str4));//false |
|  | 
 |
|  | str4 = 'as&d'; |
|  | // alert(re4.test(str4));//true |
|  | 
 |
|  | //匹配从开头到结尾有一个或多个数字、字母、下划线 |
|  | re4 = /^\w+$/; |
|  | // alert(re4.test(str4));//false |
|  | 
 |
|  | var str5 = '123adfas894fasdfas15122dfad85'; |
|  | var re5 = /\d+/g;//全文检索一个或多个数字 |
|  | var arr = str5.match(re5); |
|  | // alert(arr);//123,894,15122,85 |
|  | 
 |
|  | var re6 = /d/;//匹配字母d |
|  | // alert(str5.search(re6));//4//search相当于indexOf()函数 |
|  | 
 |
|  | //replace函数用于替换 |
|  | var str6 = str5.replace(re5, '*'); |
|  | // alert(str6);//*adfas*fasdfas*dfad* |
|  | 
 |
|  | //正则表达式的替换功能 |
|  | var s = "Once111a22wolf,3always4a5wolf!"; |
|  | var regex = /\d+/g; |
|  | var s2 = s.replace(regex, " "); |
|  | // console.log(s2); |
|  | 
 |
|  | /*叠词*/ |
|  | //快快乐乐、高高兴兴 |
|  | regex = /(.)\1(.)\2/;//()表示分组,.表示任意字符,匹配第一组任  意字符再出现一次、第二组任意字符再出现一次 |
|  | // console.log(regex.test("快快乐乐"));//true |
|  | // console.log(regex.test("快乐乐乐")); |
|  | // console.log(regex.test("高高兴兴"));//true |
|  | // console.log(regex.test("快乐快乐")); |
|  | 
 |
|  | //快乐快乐、高兴高兴 |
|  | regex = /(..)\1/;//匹配两个任意字符再出现一次 |
|  | // console.log(regex.test("快乐快乐"));//true |
|  | // console.log(regex.test("高兴高兴"));//true |
|  | // console.log(regex.test("快快快快"));//true |
|  | // console.log(regex.test("快快乐乐")); |
|  | 
 |
|  | //叠词切割 |
|  | // s = 'sdqqfgkkkhjppppkl'; |
|  | // regex = /(.)\1+/; |
|  | // var arr = s.split(regex); |
|  | // console.log(arr);//由于()中的是子表达式,会导致保留一个叠词字母,不符合要求 |
|  | 
 |
|  | s = 'sdqqfgkkkhjppppkl'; |
|  | regex = /(.)\1+/g;//匹配叠词,即多个重复的字母 |
|  | var s2 = s.replace(regex, " ");//将叠词替换为空格 |
|  | var arr = s2.split(' ');//再按照空格进行切割 |
|  | // console.log(arr);//返回["sd","fg","hj","kl"],符合要求 |
|  | 
 |
|  | //字符串替换 |
|  | var s = "我我....我...我.要...要要...要学....学学..学.编..编编.编.程.程.程..程"; |
|  | var s2 = s.replace(/\.+/g, "");//删除所有的点 |
|  | // console.log(s2); |
|  | var s3 = s2.replace(/(.)\1+/g, "$1");//全文检索叠词,替换为单个字符,例如多个“我”替换成一个“我” |
|  | // console.log(s3); |
|  | 
 |
|  | //提取手机号 |
|  | //regex = /^1[3578]\d{9}$/;手机号的正则,只能匹配17688888888     |
|  | var s = '我的手机号码是17688888888,曾经用过13187654321,还用过13512345678'; |
|  | var regex = /1[3578]\d{9}/g;//第一位是1,第二位是3578中的一个,后面9位是任意数字,并全文检索 |
|  | var arr = s.match(regex);//match方法返回匹配成功的数组 |
|  |     console.log(arr);//["17688888888","13187654321","13512345678"] |
|  | </script> |
作业
1.打印1-100之间所有奇数之和
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
  <title>Title</title>
    <title></title>
  <script type="text/javascript">
    var sum=0;
      for(var i=1;i<100;i+=2)
    {
    sum+=i;
}
document.write("100以内所有奇数和为:"+sum);
</script>
</head>
<body>

</body>
</html>

2.打印1-100之间所有7的倍数的个数及总和
  <!DOCTYPE html>
  <html lang="en">
    <head>
  <meta charset="UTF-8">
  <title>Title</title>
  <title></title>
  <script type="text/javascript">
  var count = 0;//个数
  var arr=[];
  var sum=0;
  for(var i=7;i<=100;i++) {
      if(i%7===0){
        arr[arr.length] = i;
        count++;
        sum+=i;
    }
}
console.log(count);
console.log(arr);
document.write("100所有7的倍数的总和为:"+sum);
</script>
</head>
<body>

</body>
</html>

3.水仙花数
水仙花数是指一个3位数,它的每个位上的数字的3 次幂之和等于它本身。
(  例如:1^3 + 5^3 + 3^3 = 153),请  打印所有的水仙花数。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
  <title>Title</title>
<title></title>
<script type="text/javascript">
    document.write("水仙花数有:");
for(var i=100;i<1000;i++)
{
    var a=i%10;//提取个位数
    var b=(i/10)%10 //提取十位数
    b=parseInt(b);
    var c=i/100;//提取百位数
    c=parseInt(c);
    if(i==(a*a*a+b*b*b+c*c*c))
    {
        document.write(i+",");
    }
}
</script>
</head>
  <body>

</body>
</html>

  4.在页面中接收一个用户输入的数字,并判断该数是否是质数。
质数:只能被1和它自身整除的数,1不是质数也不是合数,质数必    须是大于1的自然数。
  <!DOCTYPE html>
   <html>
   <head>
   <meta charset="UTF-8">
   <title></title>
   <script type="text/javascript">
 var num = prompt("请输入一个大于1的自然数:");

       /*创建布尔值*/
    var flag = true;
    /*判断值是否合法*/
    while(num<=1 || isNaN(num)){
        alert("这个数不合法");
        var num = prompt("请重新输入:");
    }
        for(var i = 2 ; i<num ; i++){

            /*判断i是否能被j整除*/
            if(num%i == 0){
                /*判断进入i不是质数,改变布尔值*/
                var flag = false;
                break;
            }
         }
    if(flag){

    /*flag为true则输出*/
    alert(num+"是质数");
    }else{
        alert("这个数不是质数");
    }
 </script>
  </head>
<body>

</body>
</html>

5.打印99乘法表
11=1
12=2 22=4
13=3 23=6 33=9
14=4 24=8 34=12 44=1
……
    19=9 …… 99=81
  <!DOCTYPE html>
 <html>
 <head>
 <meta charset="UTF-8">
 <title></title>
     <script type="text/javascript">
   for(var i = 1; i <=9; i++){
    var b = "";
    for (var j = 1; j <= i; j++) {
        b +=j+"×"+i+"="+(i*j)+"\t";
    }
console.log(b+"\n");
}
 </script>
</head>
<body>

    </body>
   </html>

6.打印出1-100之间所有的质数
  <!DOCTYPE html>
    <html>
   <head>
   <meta charset="UTF-8">
   <title></title>
   <script type="text/javascript">
   //打印2-100之间所有的数
   for(var i=2 ; i<=100 ; i++){
     //创建一个布尔值,用来保存结果,默认i是质数
 var flag = true;
 //判断i是否是质数
 // 获取到2-i之间的所有的数
 for(var j=2 ; j<i ; j++){
     //判断i是否能被j整除
     if(i%j === 0){
         //如果进入判断则证明i不是质数,修改flag值为false
         flag = false;
     }
     }
   //如果是质数,则打印i的值
     if(flag){
     console.log(i);
 }
 }
   </script>
  </head>
<body>

</body>
</html>

相关文章

网友评论

      本文标题:2018-12-11

      本文链接:https://www.haomeiwen.com/subject/lrtyhqtx.html