zoukankan      html  css  js  c++  java
  • Javascript的内容

      JS简介和变量

    {JS的三种方式}
                1 HTML中内嵌JS(不提倡使用)
                <button onclick="javascript:alert()">点我呀!!!</button>
            <button ondblclick="javascript:alert()">点我呀!!!</button>
            <button onmouseover="javascript:alert()">点我呀!!!</button>
                2  html页面中使用JS
                <script type="text/javascript">
                    //JS代码
            </script>
                 3 引用外部JS文件
                <script language="JavaScript"src=""></script>
                注意事项:
                页面中的JS代码和引用的JS代码 可以嵌入到HTML中的任何位置,但是位置不同,会影响JS代码的执行顺序
                ②页面中的js代码:使用type="text/javascript"
                引用外部的js文件 使用language="JavaScript"src=""
                例如<script>在body前面会在加载前出现
                  引用外部JS文件的<script></script>必须成对出现且标签内部不能有任何代码
            <script type="text/javascript">
    //            js中的注释
                // 单行注释      ctrl+/
                /*
                 段落注释     ctrl+shift+/
                 **/
    //            alert("我弹了一个窗")
    //         document.write("<h1></h1>")
    /*JS中的变量
      * 1   js中变量声明的写法
     *   var width=10;    使用var声明的变量,只在当前函数作用域有效
     * width=11;       不使用var  直接赋值生成的变量      默认为全局变量整个JS文件有效
     *  var a,b,c=1;  同一声明语句同时声明多个变量,变量之间用英文逗号分开,但 赋值需要单独赋,例如上式中的只有c赋为1
     * 2 变量的命名规范:
     *   变量名只能有字母数字下划线$ 组成
     *    开头不能使数字
     *    变量区分大小写    大写字母与小写字母为不同变量
     * 3  变量名命名要符合驼峰法则
     * 变量开头要小写     之后首字母大写  (或单词之间有下划线分隔)
     * JiangHaoIsShuaiGe
     * 4 类型JS中的变量的数据类型
     * undefined:未定义 用var声明的变量    没有进行初始化数值。  var a;
     * Null   代表特殊的变量类型。  表示为空的引用 var a=null;  
     * Boolean    真假 可选true和false
     * Number  数值类型 可以是小数,也可以是整数
     * STRING 字符串类型 用""或''包裹的内容为字符串
     * Object  (复杂数据类型) 后续讲解, 函数,数组等。
     * 5 常用的数值函数
     * isNaN  用于判断一个变量或常量   是否为非数值
     * 使用isNAN判断时,会尝试使用number()函数进行转换   如果能转换为数字 则不是非数值  结果为false
     * "111"   纯数字字符串   的、false  " "  空字符串  false  "la"  包含其他字符   true
     * true/false  布尔类型   false
     *   Number()  将其他类型转化为数值类型
     * [字符串类型]
     * 1  字符串为纯数值字符串,会转为对应的数字 "1111"》111
     * 2   字符串为空字符串  会转为"0">0
     * 3  字符串包含其他非数字字符时,不能转换,"111a">NaN
     * [NULL/undefined转数值]
     * null>0    unfedined>0
     * [Boolean类型转数值]
     * true>1    false>0
     * Object类型转数值]
     * 先通用ValueOf 方法确定函数是否有返回值 在根据上述情况判断
     * parseInt  将字符串转化为数值类型
     * >>>>  空字符串 不能转 结果为NAN
     * >>>>  纯数值字符串  能转    "123">123    "123.65">123(小数转化时,直接抹掉小数点)
     *>>>>    包含其他字符的字符串。会就取第一个非数值字符前的数值部分
     *           "1234a123">1234        "a1234">NaN
     * >>>> parseInt值能转string类型,boolem/null/undefined 均为NaN
     * parseFloa:将字符串转换为数值
     * 使用方式同parseInt,当转化小数字符串时 保留小数点,转化整数字符串时 保留整数
     * "123.5" >123.5       "123">123
     * typeof  用来检测变量数据类型
     * 未定义>undefined        字符串>string       true/false> boolean
     * 数值>number        对象/null>object          函数>function  
     * */
       /*声明变量注意事项
                *  JS中的所有变量类型声明,均使用var关键字变量的具体数据类型取决于给变量赋值的执行
                * 同一变量:可以再多次不同赋值时,修改变量的数据类型
                *  var width=10;   width为整型变量
                *  width="haha";    width被改为字符串类型
                * 变量可以使用var声明 也可以省略var  [区别]  不使用var为全局变量
                * 同一变量名可以多次用var声明 但并没有任何含义 也不会报错,第二次之后的声明      只会被理解为赋值
                * */
    var a;   // 声明变量
     a=10;  // 给变量赋值
                 JS中输入和输出语句
                 *1  文档中的打印输出   document 。write{};
                 * 输出语句 将write的()中的内容打印在浏览器屏幕上
                 * 使用时注意:改变量/常量以外的内容   打印时必须放在""中,变量/常量必须放在""外
                 * 打印内容同时有多部分内容时,中间用+链接
                 * 例如   document.write("左手中的纸牌"+left+"<br/>");
                 *   2  弹窗输出alter{}  警报
                 * 弹窗警告  ()中的内容 同上
                 * 3  弹窗输出  promptjkkk
                 * s\两部分参数 输入框上面的提示信息
                                    输入框里面的默认信息
                 * 两部分中间用逗号隔开,只写一部分,默认为提示信息
                 * 可以定义变量接受输出内容    例如var name = prompt("请输入您的名字","姜浩" );点击确定按钮 输入成功  点击取消按钮  name=null;
                 *默认接收输入的内容为字符串
                 * var center=   声明一个中间变量
                 center=left    左手的值给中间
                 right = center   把中间的值给右边 */      
           var name = prompt("请输入您的名字:","姜浩" ); 
            document.write("您的名字:"+name);
               var one =prompt("输入第一个数字:","2");
                var two = prompt("输入第二个数字:","2") ;
                var sum  = parseFloat(one)  + parseFloat(two)
              document.write(sum

    JS中的运算符

    1 算术运算
         + 加、- 减、* 乘、 / 除、 % 取余、++ 自增、-- 自减
         +:有两种作用,链接字符串/加法运算;当加号两边为数字使进行加法运算,当+号郎边有任意一边为字符串时,进行字符串链接,连接后的结果为字符串
         ++:自动运算符,将变量在原有的基础上加1
         --:自动运算符,将变量在原有的基础上减1
           n++与++n的区别
         n++:  先使用n的值来计算,然后再把n+1
         ++n :先把n的值加1,然后再用n+1以后的值去计算
         相同点:不论n++还是++n在执行完代码后,均会把n+1
         var a=3
         var b c
         b = a++  +2   a=3  b=5  a=4
         c = ++a  +2   a=4  a=5  c=7
         2 赋值运算
         =  赋值   += -=  *=  /=  %=
         +=:  a+=5;相当于    a = a  + 5  但是,前者的执行效率比后者快。
         -=:
          3关系运算
         ==、 等于  ===  严格等于    !=     不等于、>、<、>=、<
         ===:严格等于;类型不同,直接返回false,类型相同,在进行下一步判断,
         ==:等于;类型相同,同===;类型不同,尝试将等式两边转换为数字,在判断。
                      特例       null  ==   Undefined  √   null  ===  Undefined  ×
         4 条件运算符(多目运算)
         a>b?true:false
              有两个关键符号:?和:
              当问号前面的部分运算结果为true时        执行:前面的代码
              当问号前面的部分运算结果为false时      执行:后面的代码
        多目运算符可以多层嵌套      
           例如  var  jieguo = num>5?"输入太大":( num==5?"蒙对了!":"输入太小") ;  
         5逻辑运算符
         &&    与、||   或、! 非
       
                var num =5;
               
               var  jieguo = num>5?"输入太大":( num==5?"蒙对了!":"输入太小"); 
                document.write(jieguo);
              
               [运算符的优先级]
                 1  ++ --  !
                 2 *  /  %
                 3 + -
                 4 > < >=  <=
                 5 ==  !=
                 6 &&
                 7 ||
                 8   各种赋值= += *= /=  %=                                

    JS中的分支结构

    [if-else结构]
                 1 结构写法
                  if(){
                    条件为true时执行
                }else{
                    条件为false时执行
                }
                2  if()中的表达式,运算之后的结果应该为
                ① Boolean  true 真  false 假
                 string 非空字符串为真,空字符串为假。
                 Number 0为假    一切非零均为真
                 null/nan/undefined  全为假。
                 Objict :全为真。
                3 else{}结构,可以根据情况省略
                
                [多重if 阶梯if]
                 1 结构写法
                 if(条件一){
                     条件一成立
                 }else if(条件二){
                     条件一不成立&&条件二成立
                     
                     else-if 部分可以有多个
                 }else{
                     条件一不成立&&条件二不成立
                 }
                 2  多成if条件中,各种判断条件是互斥的,只能选择其中一条路。
                 3 if else的{}可以省略  但是一概不提倡
                  如果省略{}  则 if/else结构包含的代码   仅为其中最近的一行(分号结束)
                 * 如果省略{}  则else结构永远属于其前方最近的一个if
                 * */
                
             var sum =5;
                if(sum<10){
                   document.write("if条件成立")
                }else{
                    document.write("if条件不成立 ")
                }
               
    [嵌套if结构]
                 
                  1  结构写法
                  if(条件一){
                        条件一成立
                  if(条件二){
                        条件一成立&&条件二成立
                 }else{
                       条件一成立&&条件二不成立}
                  }else {
                      条件一不成立
                  if(){
                 *     111
                 * }else{
                 *     1111
                 * }
                 * }
                 * 2 if结构可多层嵌套 但原则上不可超过3层。
    /*   [switch结构]
     * 1 结构写法
     * switch(表达式){
     *         case 常量表达式1:
     *        语句1:
     *    break;
     *  case 常量表达式1:
     *        语句1:
     *    break;
      default:
       语句N
      break;  } 2 注意事项:
    switch()中的表达式,以及每个case后面的表达式,可以为任何JS支持的数据类型。对象和数组不行
    case后面的所有常量表达式,必须各不相同,否则只会执行第一个。
    case后的常量可以是任何数据类型,同一switch结构的不同case,可以使多种不同 的数据类型

    switch在进行判断的时候,采用的是全等判断     ===
    break 的作用 执行完case的代码后,弹出当前的switch结构
     缺少break的结果。
     聪明和正确的case项开始 依次执行所有的case和default
      switch结构在判断时,只会判断一次正确答案,当遇到正确的case项后将不会判断、后续项目 依次往下执行
    switch的执行速率要快于多重if结构在多路分支时,可优先选择使用switch结构

              var num4=5
               switch(num4=5){
                   case 9:
                   document.write("这是10的case块")
                   break;
                   case 10:
                   document.write("这是10的case块")
                   break;
                   default :
                document.write()
                   break;
              

    JS中的循环结构

    /*[循环结构的步骤]
                 * 声明循环变量
                 * 判断循环条件
                 * 执行循环体(while{}中所有的代码)操作
                 * 更新循环变量
                 *
                 * 然后执行 ② ③  ④
                 *
                 * [JS中循环条件支持的数据类型]
                 * Boolean  true 真  false 假
                   ② string 非空字符串为真,空字符串为假。
                   Number 0为假    一切非零均为真
                   null/nan/undefined  全为假。
                   Objict :全为真。

    //            var n = 1;   /* ①声明循环变量*/
    //            while (n<=10){   /* ②  判断循环条件*/
    //                document.write("nihao");   /*③ 执行循环体(while{}中所有的代码)操作*/
    //                n++   /*④ 更新循环变量*/
    //                n+=2
    //                n=12
    //            }
    //          
               /*while循环特点:先判断,后执行。
                * do-while循环特点:先执行 后判断。即使初始条件不成立,do-while循环也至少先执行一次
                * var m=1
                * do {
                *     
                * }while();
                *
                * */
       
    //do { 
    // var b = parseInt(prompt("请输入一个数"));
    //     if(b<7){
    //         alert("小了");
    //     }else if(b>7){
    //         alert("大了");
    //     }else if(b==7){
    //         alert("对了");
    //     }else{
    //         alert("输入有误")
    //     }
    //} while(b!=7)
    //            var n = parseInt(prompt("请输入一个整数"))
    //            while(n<=100){
    //                document.write("你赢了")
    //                n++
    //            }
                
    //            var a = parseInt(prompt("您输入的本金"))
    //            var b = 0;
    //            var num = parseFloat(prompt("数字"));
    //            var sum =a;
    //            while(b<num){
    //                sum+=sum*0.003;
    //                b++
    //            }
    //            
    //            document.write("年份"+num+"年<br />")
    //            document.write("您的本金"+a+"元<br />")
    //            document.write("您的总金额为"+sum+"元<br />");
                
    //            document.write("前"+a);

    // var num =parseInt(prompt("数字"))
    // var a = 1
    // var sum = 0;
    //    while(a<=num){
    //        sum +=a
    //        if(a!=n)document.write(a+"+")
    //        else document.write(a+"=");
    //        a++;
    //        
    //    }

    //var a =1
    //
    // var sum=0 , count=0;
    // while(a<=1000){
    //        if(a%7!=0){
    //            document.write(a+" <br />");
    //            sum+=a;
    //            count++;
    //        }
    //        a++
    // }
    //document.write("个数"+count+"<br />")
    //document.write("总和为:"+sum)


    //            var num = prompt("请输入一个三位正整数:");
    //            
    //            var bai = parseInt(num/100);
    //            var shi = parseInt(num%100/10);
    //            var ge =  parseInt(num%10);
    //            
    //            var sum  =  bai*bai*bai+shi*shi*shi+ge*ge*ge ;
    //            
    //            document .write(sum==num?"是水仙花数":"不是水仙花数")
    //
    //    var n =100;
    //    while(n<=999){
    //        var bai = parseInt(n/100);
    //        var shi = parseInt(n%100/10);
    //        var ge =  parseInt(n%10);
    //        if(n  ==  bai*bai*bai+shi*shi*shi+ge*ge*ge){
    //            document.write(n+"");
    //        }
    //        n++;
    //    }
       
    //     斐波
    //     var a=1;
    //     var b=1;
    //     var c;
    //     
    //     var n =1;
    //     while(n<=20){
    //         c=a+b   /* c=2*/
    ////         document.write(c+"<br />");
    //         a=b     /*a=1*/
    //         document.write(a+"/"+c+"<br />")
    //         b=c     /*b=2*/
    //         n++
    //     }
    //        var a = parseInt(prompt("输入的个数:"));
    //        var b =1;
    //        var sum=0;
    //        while(b<=a){
    //            var c = parseInt(prompt("请输入一个数"+b+"个数"));
    //            sum+=c;
    //            b++;
    //        }
    //       document.write("总和:"+sum)
    //        
           /*for循环
            
            * 1 for 循环有三个表达式  分别为: ① 定义循环变量 ②判断循环条件③更新循环变量
            * 三个表达式之间用;隔开
            * 三个表达式可以省略,两个;缺一不可
            * 2 for循环特点:先判断后执行
            * 3 for循环的三个表达式均可由多个部分组成,之间用逗号隔开。但是第二部分判断条件用&&链接,最终结果需要为真/假。
            * */
    //     var sum = 0 ;
    //     for(var a=1,b=100;a<b;a++,b--){
    //         if(a<50) document.write("("+a+"+"+b+")+");
    //         else document.write("("+a+"+"+b+")=");
    //         sum +=(a+b);
    //     }
    //    document.write(sum);
          var sum = 0;
            for(var a=1,b=100;a<b;a++,b--){
            if(a<50) document.write("("+a+"+"+b+")+");   
            else document.write("("+a+"+"+b+")=");
            sum +=(a+b);     
            }
           document.write(sum);

  • 相关阅读:
    正则表达式简介
    PHP中简单的页面缓冲技术
    PHP 程序加速探索
    PHP中通过Web执行C/C++应用程序
    PHP实现聊天室的主动更新与被动更新
    php中Cookie及其使用
    Linux 下 PHP 连接 MS SQLServer 的办法
    网站加速 PHP 缓冲的免费实现方法
    Spark Streaming中的基本操作函数实例
    Scala中的s函数
  • 原文地址:https://www.cnblogs.com/LJYqq/p/6658182.html
Copyright © 2011-2022 走看看