JavaScript学习笔记4

JavaScript学习笔记4

事件处理

addEventListener()
removeEventListener()
event.preventDefault()
事件冒泡(从外向内,true)和捕获(从内向外,false) - addEventListener()第三个参数
e.target
e.stopPropagation()

定时器

setTimeout() 执行一次
clearTimeout()
setInterval() 重复执行
clearInterval()

面向对象

OOP :

面向对象(函数)
构造函数(传参) – js里只能有一个构造函数!
this
…参数
匿名函数
prototype扩展 + 原型继承(.prototype)
封装 - this把变量和函数 “注册” 为属性和方法,否则为私有的?

新 - 语法糖:syntactic sugar

  • 构造函数constructor
  • getter and setter
  • symbol数据类型
  • 对象继承 - extends and super — java
function objectType(){
    this.infor = 'this is object';
    this.showInfor = function (){
        console.log(this.infor);
    }
    this.setInfor = function (msg){
        this.infor = msg;
    }
}
let newO = new objectType();
console.log(newO.infor);
newO.showInfor();
objectType.prototype.sayHello = function (){
    console.log("Hello");
}
newO.sayHello();


class Pet{
    constructor(animal,name) {
        this.animal = animal;
        this.name = name;
    }
    print(msg){
        console.log("this " + this.animal +"'s name is " + this.name);
    }
}
let pet = new Pet("cat","xiao huang");
pet.print();

DOM:

windows -> document
节点 ->

nodeType:

1 元素节点 - 2 属性节点 - 3 文本节点-…

childNodes(是一个NodeList,数组)

firstChild
lastChild
parentChild
兄弟节点(不存在就为null)
nextSibling
previousSibling
hasChildNodes()

nodeValue
nodeName

获取DOM:

document.getElementById()
document.getElementsByTagName() 有s - 数组
document.getElementsByClassName()
getAttribute()读取属性值 / attribute属性(数组)也可以访问,但是可能Firefox会有错误。

创建节点: (增加在DOM内,而不是源代码里)

document.createElement(“div”);
document.createTextNode(“文本内容”)
document.cloneNode() true or false - 即子节点复不复制

加入节点:

(innerHTML不是W3C标准)
appendChild() 添加到子节点列表的末尾
insertBefore() 确定插入位置
replaceChild() 替换子节点
removeChild() 删除节点
setAttribute() 编辑元素属性

加载顺序
  • windows.load
    页面 完成加载时触发
  • onload事件
    外部资源 完成下载并可以使用时触发
  • appendChild()
    文件 加载完成之后

DOM Core and HTML DOM

  • DOM Core 核心部分,可移植,标准的写法 如:
      dom.setAttribute("href","#item"+i)
    
  • HTML DOM 更多只适用于HTML,写法更简便 如:
    dom.href = "#item"+i
    

json

json - JavaScript对象标签
json – python字典?
json -> javascript代码:去序列化

  • eval() - 加上( ),避免含义不明确的语句
  • 浏览器支持
    • JSON.parse()
      • 将字符串转化为JSON对象
    • JSON.stringify()
      • 从一个JavaScript对象创建一个JSON编码的对象

键值对、数组、对象、方法(仅在js内)
多层次对象

canvas

canvas 2D API
默认画布大小为300x150
渲染环境 - 画

元素拖放

  • dragstart
  • drag
  • dragenter
  • dragleave
  • dragover
  • drop
  • dragend

操作本地文件

  • File
  • FileList
  • FileReader

DOM操作css

cookie

web存储 - cookie
escape()编码 unescape()解码
RFC6265标准

  • domain
  • path
  • secure
  • expires

正则表达式(regular expression,regex)

用 / / 声明正则表达式,要匹配的字符在 / / 之中。

var regex = /a/i;
if(dom.value.search(regex) == -1){
    alert('not found');
}

//后面可以跟着修饰符,控制查找方式

修饰符(标志)说明
i不区分大小写
g全局匹配
m多行匹配

[]可以控制查找方式

表达式搜索范围
[abc]a、b、c之中的任意字符(无个数限制)
[^abc]除a、b、c之外的任意字符
[0-9]0-9数字中的任意数字
[^0-9]除0-9数字之外
(a|b)选择a或者b

处理特殊字符的快捷方式:元字符(metacharacter)

元字符描述
.单个字符,除了换行符
_0个或多个字符
\d一个数字字符
\D一个非数字字符
\w一个单词字符,等同于[a-zA-Z0-9_]
\W一个非单词字符
\s一个空白字符
\S一个非空白字符
\b在一个单词的开头或结尾的一个匹配
\B不在一个单词的开头或结尾的一个匹配
\0一个空字符
\n换行字符
\f一个换页字符
\r一个回车字符
\t一个制表符
\v一个垂直制表符
\xxx八进制数xxx所指字符
\xdd十六进制数dd所指字符
\uxxxx十六进制数xxxx所指Unicode字符

限定符

限定符匹配
n+至少包含一个n的任意字符串
n*包含n的0次或多次出现的任何字符串
n?包含n的0次或1次出现的任何字符串
n{X}包含X个n的序列的字符串
n{X,Y}包含X到Y个n的序列的字符串
n{X,}至少包含X个n的序列的字符串
n$以n结尾
^n以n开头
?=n后面跟着一个字符串n
?!n后面没有跟着一个字符串n

RegExp对象

new RegExp()
test()方法
exec()方法

字符串方法使用regexp

match\search\replace\split

闭包

闭包是访问父作用域的一个函数,即便是在该作用域已经结束之后,也可以执行。
使用闭包实现数据私有性。

例子:

let x = 'apple';
var f1 = function (){
    console.log(x);
    x = 'pear';
}
x = 'banana';
var f2 = function (){
    console.log(x);
}
f1();
f2();

out:

banana
pear

模块化

export
import

技巧

在许多命令行工具中,Ctrl + c 和Ctrl+ v 并不能实现复制和粘贴的功能。相反,Ctrl + c 是停止命令。

我们需要另外一组快捷方式来复制和粘贴(windows10):

  • shift + insert 粘贴
  • ctrl + insert 复制
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值