Python web前端 06 运算符 循环
一、运算符
#JS六大数据类型#number 数字#string 字符串#boolean 布尔型#function 函数#undefined 未定义:一个变量声明之后没有复制就是未定义#object 对象在JS里面null属于对象类型,但是它不具有很多对象的共性,所以很多资料将他归为单独一类数据类型nullvar a = 11;#numbervar a = "aaa";#string js里面双引号的地方也可以用单引号来代替,不过要配对使用var a = true;#booleanvar a = function(){...} #functionvar a ;#undefinedalert(typeof a)#弹窗a的类型var a = { "name":"xiaopo","age"= "18"};#objectvar a = document.getElementById("box");#object
运算符
#算数运算符(基础数字运算)+ - * / %(取余)#当不是数字之间的运算的时候#+号两边一旦有字符串(引号引起来的一坨),那么+号就不在是数学运算了,而变成了字符串拼接,最后结果是字符串#-*%号是尽量将字符串转化成数字(隐式类型转换)隐式类型转换:即使结果不是数字,也会对这个结果进行隐式类型转换,将他的类型转换为数字
赋值运算符
+= -= *= /= %=#跟其他脚本语言一样++ -- #两个都存在隐式类型转换,会全部转换为数字var x=6;var y=++x;++x #x=x+1 y=x 先加再赋值x++ #y=x x=x+1 先赋值再加
逻辑运算符
#针对布尔值 true false#&& 与两边都为真,结果才是真,其他是假#|| 或 两边都为假,结果才是假,其他是真#! 非 取反,真变假,假变真#当逻辑运算符,两边不一定是布尔值的时候#&&遇到假就停,但是不会进行类型转 换var a = true&&1&&0&&false #弹窗弹出0(0代表假)var a = true&&1&&1&&false #弹出falsevar a= true&&1&&-2&&5 #弹出5#|| 遇到真就停,但是不会进行类型转换(假同上)#!隐式类型转换,将后面的数据先转换为布尔型在取反var a =!"0" #0是假的,转换为假后再取反,就是真var a =!"5" # 假
二、循环
1、for循环
#for循环for(var = 1;i<9;i++){ console.log(i) } #顺序依次是1、var=1 ;2、i<9 ; 3、 console.log(i) ; 4、i++ 直至条件2不满足的时候跳出循环
2、嵌套循环
for (var i =1;i<5;i++){ for(var j=1;j<3;j++){ console.log(i+";"+j); } }for(var=1;i<20;i++){ if(i==5){ break;#中断循环,终止循环,结束循环,未执行的代码不执行 continue;#跳出本次循环 } console.log(i) ;}
let
3、if循环
#if ==>布尔值#判断符> < >= <= == != !== ===== #只判断是否一样 "5"=5=== #不仅判断值,还判断类型是否一样 "5"===5 false#当if的条件 运算完后不是布尔型的时候,会强制类型转换为布尔值#以下这些值在转换以后为false#0(number); false(boolean); ""(string) ;null(object/null);undefined(undefined);NaN(number)#NaN:Not a Number 属于number类型,一般在非法运算的时候才会出现NaN, isNaN(参数)非常讨厌数字#首先尽量把参数转换为数字,然后当参数是数字,返回false;不是数字,返回true#在if里面,能用布尔值做条件判断的时候,不要用其他的来代替,因为强制数据转换需要耗费时间,在两个值比较的时候,能用三等判断的时候,就用三等判断
if(""){ alert("真");#条件为真的时候执行 }else{ alert("假");#条件为假的时候执行;当只需要真语句的时候,假语句可以不写 }#如果想要假的时候执行,真的时候不执行,在if条件里面加个!(取反)即可#还有下面两种形式来表示9>8?alert(1):alert(0);# 条件?真语句:假语句 这便是三目运算x=5>3?5:3; #如果5大于3,那么x等于5,否则x=3var x=20;if(x>20){alert("x>20");}else if(x>15){alert("x>15");}#弹窗淡出x>15,这里弹出以后,下面满足条件的不会执行了else if(x>10){alert("x>10");}else{alert(x<0);}
4、switch
var name="xiaopo";if(name==="xiaopo"){alert(name+"好漂亮");}else if(name==="小狗"){alert(name+"好帅");}else if(name==="小猫"){alert(name+"好丑");}else{alert(name+"你是谁");}#switch就可以同样实现上面的功能var name="xiaopo"switch(name){ case"xiaopo":#这里加条件 alert(name+"好漂亮"); break;#必须加上break,跳出这个循环 case"小狗": alert(name+"好帅"); break; case"小狗": alert(name+"好丑"); break; default: alert(name+"你是谁"); break; }
while和dowhile
var i = 1;for(;i<9;){ #分号必须写 console.log(i); i++; }#while类似上面var i=1;#先判断后执行while(i<9){ console.log(i); i++; }var i=10;#这个dowhile循环先执行在判断,至少会执行一次do{ console.log(i); i++; }while(i<9);
9*9乘法表
var oBox=document.getElementById("box");for(var i=1;i<10;i++){ for(var j=1;j
var aUl=document.getElementsByTagName("ul");var len=aUl.length;var index=0;for(var i =0;i
j++){ oBox.innerHTML+=""+i+"*"+j+"="+i*j+""; } oBox.innerHTML+="";}
下拉菜单