Python web前端 06 运算符 循环
Python web前端 06 运算符 循环
一、运算符
#JS六大数据类型
#number 数字
#string 字符串
#boolean 布尔型
#function 函数
#undefined 未定义:一个变量声明之后没有复制就是未定义
#object 对象
在JS里面null属于对象类型,但是它不具有很多对象的共性,所以很多资料将他归为单独一类数据类型null var a = 11;#number
var a = "aaa";#string js里面双引号的地方也可以用单引号来代替,不过要配对使用
var a = true;#boolean
var a = function(){...} #function
var a ;#undefined
alert(typeof a)#弹窗a的类型 var a = {"name":"xiaopo","age"= ""};#object
var 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 #弹出false
var a= true&&1&&-2&&5 #弹出5
#|| 遇到真就停,但是不会进行类型转换(假同上)
#!隐式类型转换,将后面的数据先转换为布尔型在取反
var a =!"" #0是假的,转换为假后再取反,就是真
var a =!"" # 假
二、循环
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) ;
}
<ul>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
<script>
var aLi=document.getElementByTagName("li")
for(var i=0,len=ali.length;i<len;i++){
aLi[i].onclick=function{
alert(i);#照常理来说,鼠标点击的li,就会弹出一个弹窗表示他的下标,但是由于这是个函数的缘故,所以弹出来的都是函数结束时的值(也就是for循环结束时i的值4),这就满足不了需求
}
}
</script> <script>
var aLi=document.getElementByTagName("li")
for(var i=0,len=ali.length;i<len;i++){
aLi[i].index=i;#index是自定义变量(可以是任何值aa,bb,vv),将每次循环的i赋值给自定义变量index
aLi[i].onclick=function{
alert(this.index);#循环结束时的i
}
}
</script>
#以后再写for循环的时候,循环里面如果有事件,就必须要赋值变量,用自定义变量存起来,不然打印出来的就是整个函数结束的i
let
<ul>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
<script>
var aLi=document.getElementByTagName("li")
for(let i=0,len=ali.length;i<len;i++){
aLi[i].onclick=function{
alert(i);
}
}
</script>
#直接用let取代var就可以直接满足要求了
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=3
var 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<i;
var aUl=document.getElementsByTagName("ul");
var len=aUl.length;
var index=0;
for(var i =0;i<len;i++){
aUl[i].qq=i;
aUl[i].onclinck=function(){
aUl[index].className="";
index=this.qq;
aUl[index].className="show";
}
}
j++){
oBox.innerHTML+="<span>"+i+"*"+j+"="+i*j+"</span>";
}
oBox.innerHTML+="<br>";
}
下拉菜单
Python web前端 06 运算符 循环的更多相关文章
- Python web前端 08 字符串 数组 json
Python web前端 08 字符串 数组 json 一.string #string 字符串 #索引 下标 偏移量 ---从0开始 str[index]; #通过索引取字符串 可读不可写 str. ...
- Python web前端 01 HTML常用标签
Python web前端 01 HTML常用标签 一.HTML创建项目 file ---->new project -----> 输入项目名------>创建文件夹 new dicr ...
- Python web前端 02 CSS
Python web前端 02 CSS 一.选择器 1.CSS的几种样式(CSS用来修饰.美化网页的) #建立模板 复制内容--->SETTING---> Editor -----> ...
- Python web前端 03 CSS属性
Python web前端 03 CSS属性 一.文字.文本属性 1.文字属性 font-family #字体类型浏览器默认的字体是微软雅黑,字体中有多个字体的时候,如果前面的字体没有就使用后面的字体 ...
- Python web前端 04 盒子模型
Python web前端 04 盒子模型 盒子模型是由内容(content).内边距(padding).外边距(margin).边框(border)组成的 一.边框 border #border 边框 ...
- Python web前端 05 JavaScript
Python web前端 05 JavaScript 一.获取元素 1.初识JavaScript /* .. */ #这是多行注释 // #这是单行注释 #JavaScript是一种脚本语言,是一种动 ...
- Python web前端 07 函数及作用域
Python web前端 07 函数及作用域 一.函数 1.有名函数和匿名函数 #函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块 #函数就是包裹在花括号里面的代码块,前面使用了关键字fun ...
- Python web前端 09 jQuery
Python web前端 09 jQuery 一.三个重要网址 http://jquery.cuishifeng.cn/ #中文查询网站 http://www.bootcdn.cn/ #引入jq ht ...
- Python web前端 11 form 和 ajax
Python web前端 11 form 和 ajax 一.打开服务器 将handlers.py.httpd.py和libs.py三个文件放入新文件夹中,双击打开httpd.py文件即可 二.ajax ...
随机推荐
- java基础之io流总结二:File类基本应用
File类的概述: File类是对文件系统中文件以及文件夹进行封装的对象,可以通过对象的思想来操作文件和文件夹. File类保存文件或目录的各种元数据信息,包括文件名.文件长度.最后修改时间.是否可读 ...
- Tarjan的强连通分量算法
Tarjan算法用于寻找图G(V,E)中的所有强连通分量,其时间复杂度为O(|V|+|E|). 所谓强连通分量就是V的某个极大子集,其中任意两个结点u,v在图中都存在一条从u到v的路径. Tarjan ...
- php学习第一天-勤劳致富
所谓“勤劳致富”,是很有科学依据的,且是经过我的亲身实践的. 自毕设突然转变为开发项目之后,整个天都变了.先是妹子给我订的票被强行取消,然后又是师兄的一句“***一小时就搞定了”,说明一下这个***是 ...
- 【bzoj2144】跳跳棋
2144: 跳跳棋 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 492 Solved: 244[Submit][Status][Discuss] ...
- mongo_1 新手之路
mongodb 进入.在bin目录下 至于安装各位自己查资料吧 .不废话了 直接上图.这种表示已经成功进入mongo 本人mongo 数据库存放地址.如有需要可以清空可以自己删除. 接下来就是 ...
- MySQL5.7插入中文乱码
参考: https://blog.csdn.net/kelay06/article/details/60870138 https://blog.csdn.net/itmr_liu/article/de ...
- 9. Palindrome Number 回文数的判断
[抄题]: Determine whether an integer is a palindrome. An integer is a palindrome when it reads the sam ...
- 2014年:Linux和开源的福祸之年
(1)Heartbleed漏洞 Heartbleed漏洞,是今年开源软件曝出的最大糗事.Heartbleed漏洞是OpenSSL的重大漏洞,这项严重缺陷(CVE-2014-0160)的产生是由于未能在 ...
- Web大文件上传控件-示例更新-Xproer.HttpUploader6.2
版权所有 2009-2016荆门泽优软件有限公司 保留所有权利 官方网站:http://www.ncmem.com/ 产品首页:http://www.ncmem.com/webapp/up6.2/in ...
- Floyd-Warshall求图中任意两点的最短路径
原创 除了DFS和BFS求图中最短路径的方法,算法Floyd-Warshall也可以求图中任意两点的最短路径. 从图中任取两点A.B,A到B的最短路径无非只有两种情况: 1:A直接到B这条路径即是最短 ...