博客列表 >class类/DOM学习

class类/DOM学习

Sinan学习博客
Sinan学习博客原创
2023年02月24日 23:15:07398浏览

1. class 声明与实例化,属性,方法,静态方法与继承的语法

学习class(类)

为了实现批量创建对象简化代码我们应该使用类,类是我们创建对象的模板。

  1. class关键字用于创建了类
  2. static关键字可以创建类的属性及方法,且只能由类访问
  3. 在类里未使用static关键字创建的属性及方法为实例属性与实例方法,只能由实例访问
  4. 构造函数constructor(){},接收实例化时的传参,并在实例化时调用。
  5. constructor(){}里的this是类本身
  6. 继承:在constructor(){}使用super()关联父类的实例属性
  7. 继承:在子类方法中使用super.xxx调用父类的实例方法
  1. //使用class关键字定义了一个Person类
  2. class Person {
  3. // name = "莫莫莫"; //Person类的实例属性,只能由实例访问
  4. // age = 30; //Person类的实例属性,只能由实例访问
  5. // gender = "男"; //Person类的实例属性,只能由实例访问
  6. static testAttribute = "这是一个静态属性, 只有用类去访问。";
  7. //实例方法,只有由实例对象访问。
  8. sayHello() {
  9. console.log("你好!我是" + this.name);
  10. }
  11. //静态方法,只有能由类访问。
  12. static testMethod() {
  13. console.log("我是静态方法,只能由类访问");
  14. }
  15. //在类中使用特殊方法constructor(),这个方法称为构造函数(构造方法)。
  16. //构造函数会在实例化对象是执行。
  17. constructor(name, age, gender) {
  18. //构造函数的形参,用于接收实例对象的实参
  19. this.name = name;
  20. this.age = age;
  21. this.gender = gender;
  22. }
  23. }
  24. //用new关键字实例化一个Person类的对象p1
  25. //当new Person()时构造函数就执行了,我理解为执行new Person() 就是调用了 constructor(){},也就是说:new Person() => constructor(){}
  26. //当创建了对象就调用了函数,所以称之为**构造函数**
  27. const zhangSan = new Person("张三", 30, "男");
  28. console.log(zhangSan.name, zhangSan.age, zhangSan.gender);
  29. //new Person(),圆括号里的参数会传递到构造函数的圆括号里的参数中。
  30. //new Person("张三",30,"男") -> constructor(name,age,gender){}
  31. console.log(Person.age); //undefined 实例属性只能由实例访问,不能用类访问。
  32. console.log(Person.testAttribute); //类属性,只有用类去访问。
  33. console.log(zhangSan.testAttribute); //undefined 类属性不能用实例对象访问。
  34. zhangSan.sayHello(); //实例方法由实例调用
  35. Person.testMethod(); //静态方法由类调用
  36. console.log("_______________________________________________");
  37. // 继承---使用关键字extends
  38. class Animal extends Person {
  39. constructor(name, age, gender, color) {
  40. super(name, age, gender);
  41. //新增实例属性
  42. this.color = color;
  43. }
  44. //重写方法
  45. sayHello() {
  46. super.sayHello(); //通过super可引入父类的方法
  47. console.log(`我是${this.name}父类的方法,也有自己的方法!`);
  48. }
  49. } // 子类Animal 继承自 父类Person
  50. Animal.testMethod(); //Animal可直接访问Person的静态方法
  51. console.log(Animal.testAttribute); //Animal可直接访问Person的静态属性
  52. //通过子类实例化对象
  53. const cat = new Animal("狸花猫", 3, "母", "黄色");
  54. console.log(cat);
  55. cat.sayHello();

2. DOM元素的获取方法演示

  1. /*
  2. 获取DOM元素的方法
  3. - 获取一组:document.querySelectorAll()
  4. - 获取一个:document.querySelector()
  5. - 获取html: document.documentElement
  6. - 获取body: document.body
  7. - 获取head: document.head
  8. - 获取title: document.title
  9. */
  10. // 获取一组元素
  11. const items = document.querySelectorAll('.list > li');
  12. console.log(items)
  13. //获取一个元素
  14. const li = document.querySelector('.list > li');
  15. console.log(li)
  16. //获取元素的内容
  17. console.log(li.textContent)
  18. //修改元素内容
  19. console.log(li.textContent = "abc")
  20. //获取html根元素
  21. console.log(document.documentElement)
  22. //获取body元素
  23. console.log(document.body)
  24. //获取head元素
  25. console.log(document.head)
  26. //获取title元素
  27. console.log(document.title)

3. DOM遍历的常用方法

  1. <ul>
  2. <li>item1</li>
  3. <li>item2</li>
  4. <li>item3</li>
  5. <li>item4</li>
  6. <li>item5</li>
  7. <li>item6</li>
  8. </ul>
  1. const ul = document.querySelector("ul");
  2. console.log(ul.nodeType); //查看节点类型
  3. console.log(ul.textContent); //获取元素文本
  4. console.log(ul.firstElementChild); //获取第一个子元素
  5. console.log(ul.firstElementChild.nextElementSibling); //获取子元素的下一个元素
  6. console.log(ul.lastElementChild); //获取最后一个子元素
  7. console.log(ul.lastElementChild.previousElementSibling); //获取子元素的上一个元素
  8. let items = ul.childNodes; //获取ul的所有子节点,包括:元素、文本(这里的文本指换行,不是元素指元素包起来的文本)
  9. console.log(items);
  10. items = ul.children; //获取ul的所有元素子节点(这通常是我们想要的)
  11. console.log(items);
  12. const li = ul.firstElementChild;
  13. const pElement = li.parentElement; //获取子元素的父元素,也可以用 parentNode
  14. console.log(pElement);
上一条:模仿淘宝网下一条:vuex学习
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议