JS学习第三周

1.节点操作

1. 创建节点

使用document.createElement()方法可以创建一个新的元素节点。例如:

var newElement = document.createElement("div");

2. 插入节点

  • appendChild():将一个节点添加到另一个节点的子节点列表的末尾。
parentElement.appendChild(newElement);
  • insertBefore():将一个节点插入到另一个节点的子节点列表的指定位置之前。
parentElement.insertBefore(newElement, referenceNode);

3. 删除节点

使用removeChild()方法可以从DOM中删除一个节点。例如:

parentElement.removeChild(childNode);

4. 替换节点

使用replaceChild()方法可以替换一个节点的子节点。例如:

parentElement.replaceChild(newNode, oldNode);

5.通过关系查找节点

父子关系

  • 父元素(Parent Element):一个元素可能包含其他元素,这些被包含的元素就是该元素的子元素,而这个包含它们的元素则被称为它们的父元素。
  • 子元素(Child Element):直接包含在另一个元素内部的元素被称为该元素的子元素。

在JavaScript中,可以通过以下属性来访问元素的父子关系:

  • parentNode获取一个元素的父节点。
  • childNodes:获取一个元素的所有子节点(包括元素节点、文本节点和注释节点)。
  • children只获取元素类型节点
  • firstChildlastChild:获取一个元素的第一个和最后一个子节点。但请注意,这两个属性可能会返回文本节点或注释节点,而不仅仅是元素节点。
  • firstChildElementChildlastElementChild这是更现代的方法,用于直接获取第一个和最后一个元素子节点,跳过文本节点和注释节点。

兄弟关系

  • 兄弟元素(Sibling Elements):具有相同父元素的元素被称为兄弟元素。

在JavaScript中,可以通过以下属性来访问元素的兄弟关系:

  • previousSiblingnextSibling:获取一个元素的前一个和后一个兄弟节点。与firstChildlastChild类似,这些属性也可能返回文本节点或注释节点。
  • previousElementSiblingnextElementSibling这是更现代的方法,用于直接获取前一个和后一个元素兄弟节点,跳过文本节点和注释节点。

2.正则表达式

正则基本使用

  1. 定义规则

    const reg =  /表达式/
    
    • 其中/ /是正则表达式字面量
    • 正则表达式也是对象
  2. 使用正则

    • test()方法 用来查看正则表达式与指定的字符串是否匹配
    • 如果正则表达式与指定的字符串匹配 ,返回true,否则false
<body>
  <script>
    // 正则表达式的基本使用
    const str = 'web前端开发'
    // 1. 定义规则
    const reg = /web/

    // 2. 使用正则  test()
    console.log(reg.test(str))  // true  如果符合规则匹配上则返回true
    console.log(reg.test('java开发'))  // false  如果不符合规则匹配上则返回 false
  </script>
</body>

元字符

  1. 普通字符:
  • 大多数的字符仅能够描述它们本身,这些字符称作普通字符,例如所有的字母和数字。
  • 普通字符只能够匹配字符串中与它们相同的字符。
  • 比如,规定用户只能输入英文26个英文字母,普通字符的话 /[abcdefghijklmnopqrstuvwxyz]/
  1. 元字符(特殊字符)
  • 是一些具有特殊含义的字符,可以极大提高了灵活性和强大的匹配功能。
  • 比如,规定用户只能输入英文26个英文字母,换成元字符写法: /[a-z]/
边界符

正则表达式中的边界符(位置符)用来提示字符所处的位置,主要有两个字符

在这里插入图片描述

如果 ^ 和 $ 在一起,表示必须是精确匹配

<body>
  <script>
    // 元字符之边界符
    // 1. 匹配开头的位置 ^
    const reg = /^web/
    console.log(reg.test('web前端'))  // true
    console.log(reg.test('前端web'))  // false
    console.log(reg.test('前端web学习'))  // false
    console.log(reg.test('we'))  // false

    // 2. 匹配结束的位置 $
    const reg1 = /web$/
    console.log(reg1.test('web前端'))  //  false
    console.log(reg1.test('前端web'))  // true
    console.log(reg1.test('前端web学习'))  // false
    console.log(reg1.test('we'))  // false  

    // 3. 精确匹配 ^ $
    const reg2 = /^web$/
    console.log(reg2.test('web前端'))  //  false
    console.log(reg2.test('前端web'))  // false
    console.log(reg2.test('前端web学习'))  // false
    console.log(reg2.test('we'))  // false 
    console.log(reg2.test('web'))  // true
    console.log(reg2.test('webweb'))  // flase 
  </script>
</body>
量词

量词用来设定某个模式重复次数

在这里插入图片描述

注意: 逗号左右两侧千万不要出现空格

<body>
  <script>
    // 元字符之量词
    // 1. * 重复次数 >= 0 次
    const reg1 = /^w*$/
    console.log(reg1.test(''))  // true
    console.log(reg1.test('w'))  // true
    console.log(reg1.test('ww'))  // true
    console.log('-----------------------')

    // 2. + 重复次数 >= 1 次
    const reg2 = /^w+$/
    console.log(reg2.test(''))  // false
    console.log(reg2.test('w'))  // true
    console.log(reg2.test('ww'))  // true
    console.log('-----------------------')

    // 3. ? 重复次数  0 || 1 
    const reg3 = /^w?$/
    console.log(reg3.test(''))  // true
    console.log(reg3.test('w'))  // true
    console.log(reg3.test('ww'))  // false
    console.log('-----------------------')


    // 4. {n} 重复 n 次
    const reg4 = /^w{3}$/
    console.log(reg4.test(''))  // false
    console.log(reg4.test('w'))  // flase
    console.log(reg4.test('ww'))  // false
    console.log(reg4.test('www'))  // true
    console.log(reg4.test('wwww'))  // false
    console.log('-----------------------')

    // 5. {n,} 重复次数 >= n 
    const reg5 = /^w{2,}$/
    console.log(reg5.test(''))  // false
    console.log(reg5.test('w'))  // false
    console.log(reg5.test('ww'))  // true
    console.log(reg5.test('www'))  // true
    console.log('-----------------------')

    // 6. {n,m}   n =< 重复次数 <= m
    const reg6 = /^w{2,4}$/
    console.log(reg6.test('w'))  // false
    console.log(reg6.test('ww'))  // true
    console.log(reg6.test('www'))  // true
    console.log(reg6.test('wwww'))  // true
    console.log(reg6.test('wwwww'))  // false

    // 7. 注意事项: 逗号两侧千万不要加空格否则会匹配失败

  </script>
范围

表示字符的范围,定义的规则限定在某个范围,比如只能是英文字母,或者数字等等,用表示范围

在这里插入图片描述

<body>
  <script>
    // 元字符之范围  []  
    // 1. [abc] 匹配包含的单个字符, 多选1
    const reg1 = /^[abc]$/
    console.log(reg1.test('a'))  // true
    console.log(reg1.test('b'))  // true
    console.log(reg1.test('c'))  // true
    console.log(reg1.test('d'))  // false
    console.log(reg1.test('ab'))  // false

    // 2. [a-z] 连字符 单个
    const reg2 = /^[a-z]$/
    console.log(reg2.test('a'))  // true
    console.log(reg2.test('p'))  // true
    console.log(reg2.test('0'))  // false
    console.log(reg2.test('A'))  // false
    // 想要包含小写字母,大写字母 ,数字
    const reg3 = /^[a-zA-Z0-9]$/
    console.log(reg3.test('B'))  // true
    console.log(reg3.test('b'))  // true
    console.log(reg3.test(9))  // true
    console.log(reg3.test(','))  // flase

    // 用户名可以输入英文字母,数字,可以加下划线,要求 6~16位
    const reg4 = /^[a-zA-Z0-9_]{6,16}$/
    console.log(reg4.test('abcd1'))  // false 
    console.log(reg4.test('abcd12'))  // true
    console.log(reg4.test('ABcd12'))  // true
    console.log(reg4.test('ABcd12_'))  // true

    // 3. [^a-z] 取反符
    const reg5 = /^[^a-z]$/
    console.log(reg5.test('a'))  // false 
    console.log(reg5.test('A'))  // true
    console.log(reg5.test(8))  // true

  </script>
</body>
字符类

某些常见模式的简写方式,区分字母和数字

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

在这里插入图片描述

替换和修饰符

replace 替换方法,可以完成字符的替换

在这里插入图片描述

<body>
  <script>
    // 替换和修饰符
    const str = '欢迎大家学习前端,相信大家一定能学好前端,都成为前端大神'
    // 1. 替换  replace  需求:把前端替换为 web
    // 1.1 replace 返回值是替换完毕的字符串
    // const strEnd = str.replace(/前端/, 'web') 只能替换一个
  </script>
</body>

修饰符约束正则执行的某些细节行为,如是否区分大小写、是否支持多行匹配等

  • i 是单词 ignore 的缩写,正则匹配时字母不区分大小写
  • g 是单词 global 的缩写,匹配所有满足正则表达式的结果
<body>
  <script>
    // 替换和修饰符
    const str = '欢迎大家学习前端,相信大家一定能学好前端,都成为前端大神'
    // 1. 替换  replace  需求:把前端替换为 web
    // 1.1 replace 返回值是替换完毕的字符串
    // const strEnd = str.replace(/前端/, 'web') 只能替换一个

    // 2. 修饰符 g 全部替换
    const strEnd = str.replace(/前端/g, 'web')
    console.log(strEnd) 
  </script>
</body>
  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 两个月Vue.js学习计划 第一: - 了解Vue.js是什么以及它的特点 - 学习Vue.js的基本语法和指令 - 创建简单的Vue实例 - 练习使用Vue的数据绑定和事件绑定 第二: - 学习Vue组件的使用 - 练习使用Vue路由 - 了解Vuex(Vue的状态管理库) - 创建一个简单的Vue项目 第三: - 学习使用Vue CLI创建和管理Vue项目 - 学习使用Axios进行Ajax请求 - 练习使用Vue进行组件间通信 - 创建一个简单的Vue项目 第四: - 学习使用Vue的动画效果 - 学习使用Vue的表单绑定 - 学习使用Vue的验证 - 创建一个简单的Vue项目 第五至八: - 练习使用Vue.js创建一个完整的项目 - 学习使用Vue的高级特性,如自定义指令和过渡效果 - 学习使用Vue的第三方库 - 创建一个简单的Vue项目 第九至十: - 学习使用Vue的服务端渲染 - 学习使用Vue的打包和部署 - 练习使用Vue与其他技术栈配合使用,如Vue+Node.js - 创建一个简单的Vue项目 每都需要练习使 ### 回答2: 学习Vue.js需要系统性的学习和实践的过程。下面是一个为期两个月的Vue.js学习计划: 第一个月: 1. 第一:先了解Vue.js的基础知识,包括Vue.js的特性和核心概念。 2. 第二学习Vue.js的基础语法和模板语法,并能够用Vue.js创建简单的应用。 3. 第三:深入学习Vue.js的组件化开发,包括组件的使用、传递数据和通信。 4. 第四学习Vue.js的路由和状态管理,掌握Vue Router和Vuex的使用方法。 第二个月: 1. 第一学习Vue.js的进阶特性,如Vue的动画和过渡效果。 2. 第二:了解Vue.js的生命期钩子函数和异步请求,学会在实际项目中使用它们。 3. 第三学习Vue.js的优化技巧和性能调优,包括代码分割和懒加载等。 4. 第四:完成一个实际的Vue.js项目,可以是一个简单的个人博客、电商网站等。 此外,还有一些额外的建议: 1. 在学习过程中多查看Vue.js的官方文档,掌握最新的特性和技术。 2. 参加一些Vue.js的社区讨论或者线上课程,与其他开发者交流经验和学习心得。 3. 实践是学习的重要环节,尽量多做一些小项目或者练习,加深对Vue.js的理解和应用能力。 通过遵循这个学习计划,希望你能够在两个月内系统地学习和掌握Vue.js,并且能够较为熟练地应用它来开发前端项目。祝你学习顺利! ### 回答3: 学习Vue.js的计划可以分为以下几个阶段,这个计划为期两个月,每个阶段大约为2-3左右。 阶段一:理论基础(1) - 了解Vue.js的基本概念和特点 - 学习Vue.js的基本语法和指令 - 掌握Vue.js的生命期和组件通信方式 阶段二:项目实践(2) - 实践一些小型项目,如制作一个简单的TodoList - 学习如何使用Vue.js进行组件开发和数据绑定 - 掌握Vue.js的路由管理和状态管理 阶段三:深入学习(2) - 学习Vue.js的原理和内部运行机制 - 掌握Vue.js的高级特性,如自定义指令和过滤器 - 学习如何使用Vue.js进行表单验证和动画效果 阶段四:项目实践升级(2) - 尝试开发一个中等复杂度的项目,如论坛或电商网站 - 进一步熟悉Vue.js的高级组件和插件库的使用 - 掌握如何进行Vue.js的优化和性能调优 阶段五:实际项目(2) - 参与一个真实的项目,与团队合作进行Vue.js的开发 - 学习如何调试和解决实际项目中的问题 - 掌握前后端的接口对接和协同开发 阶段六:总结与扩展(1) - 总结学习过程中的经验和教训 - 了解Vue.js边生态,如Vue Router和Vuex - 学习如何扩展Vue.js,如自定义指令和插件开发 在学习的过程中,可以结合官方文档、视频教程和实战项目进行学习。同时要注重动手实践,通过编写代码来加深理解和掌握Vue.js的知识。另外,也可以参加一些线上或线下的Vue.js培训和交流活动,与其他开发者分享经验和解决问题。总之,坚持不懈、持续学习是掌握Vue.js的关键。祝你学习愉快!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值