vue基础知识笔记04

vue

1、路由库Vue-Router

​ 帮助我们实现页面跳转,跟a标签一样,Vue是单页面SPA局部更新,通过Vue Router帮助我们进行路由跳转。

1.1 路由的安装

​ 通过脚手架 选择路由选项,直接安装

1.2 路由配置

​ 1、建 – 创建Vue大页面

​ 2、配 – 配置路由选项 {path:‘/recommend’,component:Recommend}, 进行访问路径跟大页面的关联,一一对应关系

​ 3、设置出口及测试 – 设置页面的渲染位置及元素、输入地址测试否能跳转

一级路由的出口在跟组件上App.vue,通过一个VueRouter自带的标签 <router-view></router-view>
嵌套路由出口在父组件上

​ 4、添加导航 – 添加导航栏

通过<router-link to="跳转地址">跳转名字</router-link>标签实现跳转,底层是a标签,但是功能更强大;
还可以通过class ".router-link-active" 进行选中样式的配置

1.3 嵌套路由(二级以上的路由)

​ 1、建 – 创建Vue大页面

​ 2、配 – 配置路由选项 {path:‘/xx’,component:Recommend}, 进行访问路径跟大页面的关联,一 一对应关系

​ 3、设置出口及测试

​ 4、添加导航

1.4 设置重定向

​ 1 首页的重定向: {path:‘/’,redirect:‘/你希望重定向的地址’},

​ 2 嵌套路由的重定向:redirect:‘/你希望重定向的地址’,

2.5 路由模式 (mode)

​ hash 哈希模式 ,路由地址中多了一个#号 (了解:底层实现是一个叫做 onHashChange ())

​ history 历史模式 ,路由中没有#号 (了解 : 底层实现是H5 一个叫做pushState() )

对比【面试题】:

​ hash模式从开发到打包上线,不存在问题,都是一样的

​ history模式在开发时不存在问题,但是打包之后的页面不能刷新,否则出现404找不到页面,(解决办法:请后端工程师帮忙在代理服务器nginx里配置刷新重定向,就好了)

1.6 路由的传参

路由的跳转 this.$router.push(‘/路径’)

方式一: 页面刷新数据也存在,但是对象及数组会丢失

query传参:
this.$router.push({
    path:'/路径',
    query:{
        id:111,
        name:'xxx'
    }
})
query的接收:
this.$route.query  // { id:111,name:'xxx'}

方式二: 页面刷新数据就会失效,但是可以携带对象及数组

params传参:
this.$router.push({
    name:'路由名称',
    params:{
        id:111,
        name:'xxx'
    }
})

params的接收:
this.$route.params  // { id:111,name:'xxx'}

解决办法:用本地缓存存储及获取数据 sessionStorage,params的使用场景一般在移动端无刷新功能的页面上

方式三:【了解】

动态路径传参:

1.在路由配置里设置
{path:'路径/:变量名',component:组件名}

2.在跳转页面传参
this.$router.push('路径/123123')

3.在目标页面进行接收
this.$route.params

1.7 路由的两个内置对象

$router: 路由实例对象,主要作用提供跳转方法 ( === new VueRouter)

​ this.$router.push()

​ this.$router.go(-1)

$route:路由信息对象,主要提供路由相关页面的信息

​ query

​ params

​ path

1.8 路由守卫 – 权限控制

​ 路由前置守卫:

router.beforeEach((to,from,next)=>{
    	to // 去往哪里
        form // 来自哪里
        next // 是否放心 没有参数就直接放心,有参数就是跳转到指定页面
})

2.0 Vue内置Api

2.1 ref

​ 他就相当于是dom选择器,如果对页面节点使用就直接获得节点元素,如果对组件使用,可以获得组件的实例对象(相当于组件里的this)

• 语法: this.$refs.ref的值

<组件或节点 ref="变量名"></组件或节点>

<script>
    export default{
		methods:{
            fn(){
                // 可以获取dom节点的元素或组件的实例对象
                this.$refs.变量名
                
            }
        }
	}
</script> 

2.2 Vue.set

​ **对象:**Vue.set作用:重新挟持数据, 让数据具备响应式.

语法:

Vue.set(对象,属性名,新属性值) // 就可以让对象重新具有响应式

this.$set(对象, 属性名, 新属性值) // 与第一种是一样的

数组: 变更方法:Vue重写了以下数组方法,让以下操作数组时会具备响应式

push()
pop()
shift()
unshift()
splice()
sort()
reverse()

2.3 Vue.nextTick

​ 作用:在下一次页面dom更新后调用nextTick里的代码

​ 语法:

Vue.nextTick(()=>{
    // 下一次的Dom节点
})

this.$nextTick(()=>{
    console.log(this.$refs.test)
})

2.4 Vue.filter

​ 作用:定义在全局的过滤器,可以在任何.vue文件中调用,用于处理数据格式

Vue.filter('过滤器函数名',(data)=>{
    // 处理data数据
    return '结果'
})

2.5 Vue.component

​ 作用:定义在全局的组件,在任何地方都能用

Vue.component('组件名',引入的组件)

2.6 Vue.use

作用:安装使用Vue周边提供的插件(只要是用Vue写的插件,都需要用use使用一下)

2.7 Vue.directive

​ 作用:Vue 允许我们写自己定义的指令,可以在里面定义各种操作

Vue.directive('自定义指令名',{
  bind: function () {},
  inserted: function () {**********
      
      在里面进行相应的操作
      
  }, 
  update: function () {},
  componentUpdated: function () {},
  unbind: function () {}
})

// 自定义的指令
Vue.directive('ellipsis',{
  inserted:(dom,obj)=>{
    dom.style.width = obj.value +'px'
    dom.style.textOverflow = 'ellipsis';
    dom.style.overflow = 'hidden';
    dom.style.whiteSpace = 'nowrap';
  }
})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 尚硅谷的Vue MD笔记是一份非常优秀的学习资料。通过这份笔记,我能够系统地学习和掌握Vue.js框架的核心知识和技能。 首先,Vue MD笔记详细介绍了Vue.js的基本概念和核心特性,包括数据绑定、指令、组件等。通过学习这些基础知识,我能够清楚地理解Vue.js的工作原理和实现机制。 其次,笔记中还提供了大量的实例演示和代码示例,这对我来说非常有帮助。通过这些实例,我能够深入了解Vue.js的使用方法和技巧,同时也可以通过模仿和修改代码来练习和巩固所学的知识。 此外,笔记中还介绍了Vue.js在实际项目中的应用场景和开发经验,这对我在实际开发中的指导非常有帮助。我学会了如何搭建Vue.js项目,如何使用Vue CLI、Vue Router等常用工具和插件,并了解了一些Vue.js的最佳实践和性能优化技巧。 最后,我觉得笔记的编写方式非常清晰和易于理解。它使用了简洁明了的语言,配合大量的图表和示意图,能够很好地帮助我理解和记忆所学的知识点。 总体而言,尚硅谷的Vue MD笔记是一份非常宝贵的学习资料。通过学习这份笔记,我能够系统地学习和掌握Vue.js框架的核心知识和技能,并在实际项目中灵活运用。我相信,这份笔记将帮助我成为一名优秀的Vue.js开发者。 ### 回答2: 尚硅谷Vue.md笔记是一份学习Vue框架的笔记资料,它包含了Vue的基本概念、核心特性和使用方法等内容。 这份笔记首先介绍了Vue的起源和背景,简要讲解了Vue是一个响应式的JavaScript框架,能够轻松构建用户界面。接着,笔记详细介绍了Vue中的数据绑定、指令、计算属性、组件化等核心概念和特性。通过学习这些内容,我们可以更好地理解Vue的工作原理和使用方法。 此外,笔记还特别强调了Vue与其他框架的比较和优劣势分析,帮助我们更好地选择适合自己项目的技术栈。同时,笔记中也提供了大量的实例代码和示例,通过实践练习可以更好地掌握Vue的使用。 还有一个关键的特点是笔记的结构清晰、重点突出,对于各个知识点的讲解都较为详细,同时也提供了相关的参考资料和学习资源,方便我们进一步深入学习和扩展。 总之,尚硅谷Vue.md笔记是一份非常有价值的学习资料,对于想要学习Vue框架的开发者来说,它可以帮助我们快速入门和深入学习,并且提供了丰富的实例和相关资源,是一份非常推荐的学习材料。 ### 回答3: 《尚硅谷Vue.md笔记》是一本关于Vue.js技术的学习笔记,内容丰富全面。本书主要包含了Vue.js的基础知识、进阶技巧和实战项目等方面的内容。 首先,本书的前部分介绍了Vue.js的基本概念和核心特性,如数据绑定、指令、组件、路由等。通过对这些知识点的深入讲解,读者可以很好地理解Vue.js的设计原理和运行机制。 其次,本书的中部内容涵盖了Vue.js的进阶技巧和最佳实践。作者通过实例代码和详细的讲解,介绍了Vue.js的高级特性和常用的组件开发方法。此外,还介绍了一些优化和调试技巧,帮助读者提升Vue.js应用的性能和开发效率。 最后,本书的后部分是一些实战项目,作者通过开发一些常见的网页应用,如购物车、音乐播放器等,来帮助读者巩固所学的Vue.js知识。通过实践,读者能够学会如何将Vue.js应用到实际项目中,并了解如何解决实际开发中遇到的问题。 总体来说,本书不仅系统地介绍了Vue.js的核心概念和基本用法,还通过丰富的实例和实战项目,帮助读者更好地理解和应用所学的知识。对于想要学习Vue.js的初学者和有一定经验的开发者来说,这本书是一份优秀的学习资料。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值