python全栈开发day44-js、DOM、BOM
JS的三大部分
一、ECMAJavaScript基础语法:
1.javascript的引入方式
1) 行内式
<script>
alert(1)
</script>
2) 引入式
<script src='test.js'> </script>
2.javascript基础语法
1) 几个简单的函数
alert()、 # 警告对话框
confirm()、# 确认对话框
prompt()、 # 输入对话框,接收的为字符串
console.log() # 控制台 输出
console.dir() # 可以显示一个对象的所有属性和方法
document.write() # 向网页文档中输出了一段文字
typeof(变量) # 类型查询
语法规则:JavaScript对换行、缩进、空格不敏感,语句末尾加分号,单行注释// 多行注释/* */
2) 直接量、变量
(1) 直接量:数字99和字符串“99”
(2) 变量的定义、赋值、命名规范
var a ;
a = 1 ;
· 变量名的命名规范:只能由英语字母、数字、下划线、美元符号$构成,且不能以数字开头,并且不能是JavaScript保留字。并且区分大小写。
Camel 标记法
首字母是小写的,接下来的字母都以大写字符开头。例如:
var myTestValue = 0, mySecondValue = "hi";
Pascal 标记法
首字母是大写的,接下来的字母都以大写字符开头。例如:
Var MyTestValue = 0, MySecondValue = "hi";
匈牙利类型标记法
在以 Pascal 标记法命名的变量前附加一个小写字母(或小写字母序列),说明该变量的类型。例如,i 表示整数,s 表示字符串,如下所示“
Var iMyTestValue = 0, sMySecondValue = "hi";
变量名书写种类
3) 数据类型
基础数据类型:
String:模板字符串·模板字符串&{name}·
Number:
Number.MAX_VALUE,Number.MIN_VALUE.
NaN不等于NaN
isNaN('test') #true
Infinity
Boolean:
Null:
Undefined:
引用数据类型:
Array:数组
(1) 数组的创建:
字面量方式:var a = ['a','b']
构造函数:var a = new Array();
(2) 赋值
a[0] = 'a';
a[1] = 'b';
(3) 方法:
concat():把几个数组合并成一个数组;
join():返回字符串,将数组中的元素,用指定的字符串连接起来
pop():删除数组最后一个元素并返回
push():向数组的末尾添加一个或更多元素,并返回新的长度。
shift() :删除并返回数组的第一个元素;
unshift():向元组的开头添加一个或多个元素,并返回新数组的长度。
sort():对数组的数据进行排序。
reverse():颠倒数组中的元素的顺序。
slice():切片,左闭右开
splice(): 删除元素,个数,添加新元素。
toString():将数组中所有的元素合在一块用逗号隔开,便构成一个长字符串。
isArray():
indexOf(): 索引位置或-1
(4) 属性
length
prototype
String:
(1) 创建
(2) 赋值
(3) 属性
(4) 方法
charAt() : 返回指定索引的位置的字符;
concat():返回新字符串,将两个或多个字符串拼接。
match():返回正则表达式模式对字符串进行查找,并将包含查找结果作为结果返回。
replace(a,b) 字符串b替换a
search() 指明是否存在相应的匹配,存在则返回这个匹配距离字符串开始的偏移量。如果没有找到匹配,返回-1
slice():切片
split('a',1):分割字符串,并制定返回数组的长度
substr():截取子字符串
toUpperCase():
toLowerCase():
Date:
1.创建,只有构造方法一个方式,Date()
2.方法
getDate():(1-31)一个月的第几天
getDay():(0-6)一个星期的第几天
getMonth():(0-11)一年中的第几个月
getYear():四位数年份
getHours():
getMinutes():
getSeconds():
mydata.toLocalString()
Object:protoType
Math:
Math.floor():
.ceil()
.max(a,b)
.min(a,b)
random() 0~1包含0不包含1
max-min之间的随机数:min+Math.random()*(max-min)
4) 数据类型转换
- 数字 + 字符串:数字转换为字符串
- 数字 + 布尔值:true转换为1,false转换为0
- 字符串 + 布尔值:布尔值转换为字符串true或false
- 转换成字符串:toString()
- 转换成数字:parseInt()
- 转化成浮点数:parseFloat()
- 强制类型转换:String()、Boolean()、Number()
5) 流程控制
# if(){}else{}
# if(){}else if(){}else{}
# && ||
# while(){}
# do{}while()
# for(var i=0;i<10;i++){}、
# switch(条件){ // 注意case穿透问题
case 1:
执行语句;
break;
case 2:
执行语句;
break;
。。。。。。。。
default:
执行语句;
}
6) 函数
避免重复,让编程模块化。
函数定义的几种形式:
function 函数名(){};
var 函数名= function(){};
箭头形式定义:
var f=v=>v 等同于var f = function(v){return V;};
var sum=(sum1,sum2)=>sum1+sum2;
等同于:
var sum = function(sum1,sum2){
return sum1+sum2;};
函数的实参数量可以大于形参数量。
引申:定义类?名字首字母大写,伪面向对象。
function Add(){};
var a = new Add()
7) 伪数组
有数据的长度和索引,但是没有数组的方法。
fn(2,4);
fn(2,4,6); fn(2,4,6,8); function fn(a,b,c) { console.log(arguments); console.log(fn.length); //获取形参的个数 console.log(arguments.length); //获取实参的个数 console.log("----------------"); }
var array = [1,2,3,4,5,6]; array.splice(0); //方式1:删除数组中所有项目
array.length = 0; //方式1:length属性可以赋值,在其它语言中length是只读
array = []; //方式3:推荐
二、DOM 文档对象模型,操作网页上的元素的API。
(一)、事件
JS是以事件驱动为核心的一门语言。
事件的三要素:
事件源、事件、事件驱动程序。
常见事件如下:
onclick:鼠标单击
ondblclick:鼠标双击
onmouseover:鼠标悬停
onmouseout:鼠标移出
onkeyup:按下并释放键盘上的一个键时触发
onchange:文本内容或下拉菜单中的选项发送改变
onfocus:获取焦点,表示文本框等获得鼠标光标
onblur:失去焦点,表示文本框等失去鼠标光标
onload:网页文档加载事件
onunload:关闭网页时
onsubmit:表单提交事件、
onreset:重置表单时。
1.获取事件源的方式(DOM节点的获取)
var
div1 = document.getElementById(
"box1"
);
//方式一:通过id获取单个标签
var
arr1 = document.getElementsByTagName(
"div1"
);
//方式二:通过 标签名 获得 标签数组,所以有s
var
arr2 = document.getElementsByClassName(
"hehe"
);
//方式三:通过 类名 获得 标签数组,所以有s
2.绑定事件的方式
1) 直接绑定匿名函数
div1.onclick=function(){};
2) 先单独定义函数,再绑定(注意函数名不带括号)
div.onclick = fn;
function fn(){};
3) 行内绑定(绑定函数名fn())
<div id="box1" onclick="fn()"></div>
3.事件驱动程序
1) 操作标签属性和样式
注意两点:
(1) 在js里写属性值时,要用引号
(2) 在js里写属性名 -变成驼峰形式,backgroud-color->backgroudColor
标签自带属性class-》className
2) onload事件
当文档加载(先文本后图片)完毕的时候,触发onload事件
有一点我们要知道:js的加载是和html同步加载的。因此,如果使用元素在定义元素之前,容易报错。这个时候,onload事件就能派上用场了,我们可以把使用元素的代码放在onload里,就能保证这段代码是最后执行。
建议是:整个页面上所有元素加载完毕在执行js内容。所以,window.onload可以预防使用标签在定义标签之前。
(二)、DOM
1.DOM树
1) 节点
元素节点:HTML标签
文本节点:标签中的文字(比如标签之间的空格、换行)
属性节点:标签的属性
整个html文档是一个文档节点。所有的节点都是object
2) DOM节点有啥用?
找对象(元素节点)
设置元素的属性值
设置元素的样式
动态创建和删除元素
事件的触发响应:事件源、事件、事件的驱动程序
(3)DOM节点的三种获取方式
(4) DOM访问关系的获取
父节点:
parentNode
兄弟节点:
nextSibling
nextElementSibling
previousSibling
previousElementSibling
子节点:
firstChild
firstElementChild
lastChild
lastElementChild
所有子节点:
childNodes
children
多种浏览器支持方式:下一个兄弟节点 = 节点.nextElementSibling || 节点.nextSibling
节点自己.parentNode.children[index]; //随意得到兄弟节点
这里讲一下nodeType。
nodeType == 1 表示的是元素节点(标签) 。记住:元素就是标签。
nodeType == 2 表示是属性节点 了解
nodeType == 3 是文本节点 了解
新的标签(元素节点) = document.createElement("标签名");
插入节点:
两种方式:
父节点.appendChild(新的子节点);
父节点.insertBefore(新的子节点,作为参考的子节点);
删除节点:
父节点.removeChild(子节点);
复制节点:
要复制的节点.cloneNode(); //括号里不带参数和带参数false,效果是一样的。 要复制的节点.cloneNode(true);
(6) 设置节点属性:
a.获取节点的属性值
方式1:
元素节点.属性;
元素节点[属性];
方式2: 元素节点.getAttribute("属性名称");
b.设置节点属性:
1. myNode.src = "images/2.jpg" //修改src的属性值
myNode.className = "image2-box"; //修改class的name
2.元素节点.setAttribute(属性名, 新的属性值);
c.删除节点属性
元素节点.removeAttribute(属性名);
三、BOM
四、预习和扩展
1.innerHTML、innerText 、value
innerHTML:获取的是当前元素下的标签和文本 +=‘<a href="#">haha</a>’;
innerText:获取的是所有的文本 +='增加文本内容'
value:获取的是input元素输入内容。
2 创建对象的几种常用方式
1.使用Object或对象字面量创建对象
2.工厂模式创建对象
3.构造函数模式创建对象
4.原型模式创建对象
3. 考试题练习:
47、[1,2,3]+[4,5,6]的结果是多少?
两个列表相加,等价于extend
48、提高python运行效率的方法
1、使用生成器,因为可以节约大量内存
2、循环代码优化,避免过多重复代码的执行
3、核心模块用Cython PyPy等,提高效率
4、多进程、多线程、协程
5、多个if elif条件判断,可以把最有可能先发生的条件放到前面写,这样可以减少程序判断的次数,提高效率
4. this的四种用法:
this是Javascript语言的一个关键字。
它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用。比如,
function test(){
this.x = 1;
}
随着函数使用场合的不同,this的值会发生变化。但是有一个总的原则,那就是this指的是,调用函数的那个对象。
1.在一般函数方法中使用 this 指代全局对象 1
2
3
4
5
function test(){
this.x = 1;
alert(this.x);
}
test(); //
2.作为对象方法调用,this 指代上级对象 复制代码
function test(){
alert(this.x);
}
var o = {};
o.x = 1;
o.m = test;
o.m(); //
复制代码
3.作为构造函数调用,this 指代new 出的对象 复制代码
function test(){
this.x = 1;
}
var o = new test();
alert(o.x); //
//运行结果为1。为了表明这时this不是全局对象,我对代码做一些改变:
var x = 2;
function test(){
this.x = 1;
}
var o = new test();
alert(x); //
复制代码 4.apply 调用 ,apply方法作用是改变函数的调用对象,此方法的第一个参数为改变后调用这个函数的对象,this指代第一个参数 复制代码
var x = 0;
function test(){
alert(this.x);
}
var o={};
o.x = 1;
o.m = test;
o.m.apply(); //
//apply()的参数为空时,默认调用全局对象。因此,这时的运行结果为0,证明this指的是全局对象。如果把最后一行代码修改为 o.m.apply(o); //
this的四种用法
python全栈开发day44-js、DOM、BOM的更多相关文章
- Win10构建Python全栈开发环境With WSL
目录 Win10构建Python全栈开发环境With WSL 启动WSL 总结 对<Dev on Windows with WSL>的补充 Win10构建Python全栈开发环境With ...
- python全栈开发中级班全程笔记(第二模块、第四章(三、re 正则表达式))
python全栈开发笔记第二模块 第四章 :常用模块(第三部分) 一.正则表达式的作用与方法 正则表达式是什么呢?一个问题带来正则表达式的重要性和作用 有一个需求 : 从文件中读取所有联 ...
- python 全栈开发,Day99(作业讲解,DRF版本,DRF分页,DRF序列化进阶)
昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...
- Python全栈开发相关课程
Python全栈开发 Python入门 Python安装 Pycharm安装.激活.使用 Python基础 Python语法 Python数据类型 Python进阶 面向对象 网络编程 并发编程 数据 ...
- Python 全栈开发【第0篇】:目录
Python 全栈开发[第0篇]:目录 第一阶段:Python 开发入门 Python 全栈开发[第一篇]:计算机原理&Linux系统入门 Python 全栈开发[第二篇]:Python基 ...
- Python全栈开发【面向对象进阶】
Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...
- Python全栈开发【面向对象】
Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...
- Python全栈开发【模块】
Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...
- Python全栈开发【基础四】
Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...
随机推荐
- IP地址分类以及子网划分
五类IP地址段 根据上表的说明,我们可以知道: 你只要知道 IP 的第一个十进制数,就能够约略了解到该 IP 属于哪一个等级, 以及同网域 IP 数量有多少. 这也是为啥我们上头选了 192.168. ...
- 使用Eclipse Memory Analyzer 进行JAVA内存泄露分析
一,安装 Eclipse Memory Analyzer 在Memory Analyzer的官网找到 update site的地址:
- JAVA 动态代理学习记录
打算用JAVA实现一个简单的RPC框架,看完RPC参考代码之后,感觉RPC的实现主要用到了两个方面的JAVA知识:网络通信和动态代理.因此,先补补动态代理的知识.---多看看代码中写的注释 参考:Ja ...
- C++ error LNK2001
1.没有函数的实现部分 2.函数的头文件和实现部分不一致 3.缺库LIB.DLL 4.库H文件函数和库体不一致
- Linux - 包不同安装方式
rpm 软件包管理器 安装编译包好的二进制包 方式 rpm -ivh lynx # rpm安装 rpm -e lynx # 卸载包 rpm -e lynx --nodeps # 强制卸载 rpm -q ...
- loadrunner函数解密之web_reg_find
loadrunner工具的使用,最关键的在于3个地方: A:脚本的编写 B:场景设计 C:性能测试结果分析 其中难度比较大的第一步是:编写脚本,有很多人对于loadrunner里面的各种函数使用的并不 ...
- TCP传输协议
TCP是主机对主机层的传输控制协议,提供可靠的连接服务,采用三次握手确认建立一个连接,四次挥手断开连接. 三次握手 是指建立一个TCP连接时,需要客户端和服务端总共发送3个包以确认连接建立成功.在so ...
- android 使用web查看SQLite数据
添加依赖: compile 'com.facebook.stetho:stetho:1.4.2'compile 'com.facebook.stetho:stetho-okhttp3:1.4.2' 初 ...
- ROS中的CMakeLists.txt
在ROS的编程过程中,如果CMakeLists.txt如果写不好,编译就很难成功.如果看不懂CMakeLists.txt那么很多错误你也不知道时什么回事.所以深入了解它是很有必要的.现在我们就来看看它 ...
- 泰克TDS1000B示波器使用说明
1.前言 本文主要根据泰克官方网站TDS1000B/TDS2000B使用教程视频进行整理. 2.认识你的示波器 TDS1000B带宽从40MHZ到200MHZ,采样率高达2Gbps