Blogger Information
Blog 41
fans 0
comment 0
visits 31264
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
构造函数和dom元素的常用方法
陈强
Original
680 people have browsed it

构造函数的基本概念

  • 任何一个函数都有一个原型属性: prototype ,即使是空函数
  1. function f1() {}
  2. console.dir(f1);

  • 声明一个构造函数,函数名首字母大写
  1. function User() {};
  • 初始化对象,给这个对象添加一个自定义属性,用来和其它实例进行区分
  1. function User(name) {
  2. this.name = name;
  3. };
  • 创建对象的过程,就叫“类的实例化”
  1. const user = new User('jack');
  • 需要被所有类实例共享的成员,应该写到构造函数的原型上
  1. User.prototype.age = 18;
  2. console.log(user.age);

  • 属性通常不应该共享的,它是区分不同对象的标志,方法更适合共享;方法要写在构造函数体外会被共享,写在内是私有,不会被共享
  1. User.prototype.show = function () {
  2. return { name: this.name };
  3. };
  4. console.log(user.show());

类与继承

类的基本概念

  • 构造函数模拟类
  1. class User {
  2. constructor(name, age) {
  3. this.name = name;
  4. this.age = age;
  5. }
  6. }
  • 静态方法: 不需要通过对象调用,直接用类调用就行
  1. static show() {
  2. return this.tell(this.gender);
  3. }
  4. static gender = "fale";
  5. static tell(gender) {
  6. return gender;
  7. }
  8. console.log(User.show());
  • 私有成员,只能在本类中使用,类外,子类中都不能用
  1. #money = 100;

类的继承

  • 子类扩展父类的功能,可以拥有自己的属性或方法
  • 子类中可以访问并继承父类的构造方法,原型方法,静态方法,不能访问私有成员
  1. class User1 extends User {
  2. constructor(name, age, money) {
  3. //super用来继承父类属性
  4. super(name, age);
  5. this.money = money;
  6. }
  7. }
  8. //子类继承父类的静态方法
  9. console.log(User1.show());

dom元素的增删改查

  • 获取元素
  1. //获取第一个元素
  2. document.querySelector()
  3. //获取全部元素
  4. document.querySelectorAll()
  • 创建元素
  1. document.createElement();
  • 增加元素
  1. let htmlStr = "<li>item5</li>";
  2. lis.insertAdjacentHTML("beforeEnd", htmlStr);
  • 增加大量元素 使用文档片断
  1. const frag = new DocumentFragment();
  2. for (i = 0; i < 5; i++) {
  3. const li = document.createElement("li");
  4. li.textContent = "add " + (i + 1);
  5. //将生成的节点先临时挂载到文档片断中
  6. frag.appendChild(li);
  7. }
  8. lis.appendChild(frag);
  • 更新元素
  1. let h3 = document.createElement("h3");
  2. h3.innerHTML = "123333";
  3. lis.replaceChild(h3, document.querySelector("li:last-of-type"));
  • 移除元素
  1. lis.removeChild(document.querySelector("span"));
  • 遍历查询
  1. //获取所有元素
  2. console.log(lis.children);
  3. //获取所有元素的数量
  4. console.log(lis.childElementCount);
  5. //获取第一个子元素
  6. console.log(lis.firstElementChild);
  7. //获取最后一个子元素
  8. console.log(lis.lastElementChild);
Correcting teacher:天蓬老师天蓬老师

Correction status:qualified

Teacher's comments:现在有一组与jQuery一样的原生api,可以了解一下
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post