vue.js及项目实战[笔记]— 03 vue.js插件
一. vue补充
1. 获取DOM元素
- 救命稻草,
document.querySelector
- 在template中标示元素`
ref = "xxx"
- 在要获取的时候,
this.$refs.xxx
获取元素- 创建组件,装载DOM,用户点击按钮
ref
在DOM上获取的是原生DOM对象ref
在组件上获取的是组件对象$el
是拿其DOM- 这个对象就相当于我们平时玩的this,也可以直接调用函数
总结:
$属性:$refs获取组件内的元素
$parent:获取当前组件对象的父组件
$children:获取子组件
$root:获取new Vue 的实例 vm
$el:组件对象的DOM元素
重点:理解 $nextTick 的作用,参考:
Vue.nextTick 的原理和用途
二. 路由
1. 路由原理
- 传统开发方式url改变后立刻发起请求,响应整个页面,渲染整个页面
SPA
锚点值改变后不会发起请求,发起ajax
请求,局部改变页面数据- 页面不跳转,用户体验更好
2. SPA
- single page application(单页面应用程序)
- 前端路由
- 锚点值监视
- ajax获取动态数据
- 核心点是锚点值
- 前端框架Vue/angular/react都很适合开发单页面程序
3. 基本使用
vue-router
- 其实vue的核心插件
- 1. 下载
npm i vue-router -S
- 2. (重要):安装插件
Vue.use(VueRouter)
- 3. 在main.js中引入
vue-router
对象:import router from './x.js'
- 4. 创建路由对象
var router = new VueRouter()
- 5. 配置路由规则
router.addRouters([路由对象])
- 路由对象
{path:'锚点值',component:要(填坑)现实的组件}
- 路由对象
- 6. 将配置好的路由对象交给
Vue
- 在
options
中传递->key
叫做router
- 在
- 7.留坑(使用组件)
<router-view></router-view>
4. router-link
to
- 帮助我们生成
a
标签的href
- 锚点值代码维护不方便,如果需要改变锚点值名称
- 则需要改变[使用次数+1(配置规则)]个地方的代码
### 5. 命名路由
- 则需要改变[使用次数+1(配置规则)]个地方的代码
- 1. 给路由对象一个名称
{name:'home',path:'/home',component:Home}
- 2. 在
router-link
的to
属性中描述这个规则<router-link :to="{name:'name'}"></router-link>
- 通过名称找路由对象,获取其path,生成自己的href
- 大大降低维护成本,锚点值改变只用在main.js中改变path属性即可
阶段总结:
** vue-router使用步骤:
1. 引入
2. 安装插件
3. 创建路由实例
4. 配置路由规则
5. 将路由关联Vue
6. 填坑
** router-link to = "/xxx"命名路由:
1. 在路由规则对象中加入name属性
2. 在router-link中 :to="{name:'xxx'}"
** 生僻API梳理:
1. Vue.use(插件对象); // 过程中会注册一些全局组件,及给vm或者组件对象挂载属性
2. 给vm及组件对象挂载的方式:
Object.defineProperty(Vue.prototype,'$router',{
get:function(){
return 自己的router对象
}
})
重点:vue.js关于Object.defineProperty的利用原理,参考:
Object.defineProperty()
6. 参数router-link
Vue.prototype.xxx = {add:fn}
- 所有组件中,使用
this.xxx
就能拿到这个对象 - 查询字符串
- 1. 配置:
:to="{name:'detail',query:{id:hero.id}}"
- 2. 规则
{name:'detail',path:'/detail',component:Detail}
- 3. 获取
this.$route.query.id
- 4. 生成
<a href="/detail?id=1">
- 1. 配置:
- path方式
- 1. 配置
:to="{name:'detail',params:{id:hero,id}}"
- 2. 规则
{name:'detail',path:'detal/:id'}
- 3. 获取
this.$route.params.id
- 4. 生成
<a href="detail/1">
- 1. 配置
- 查询字符串配置参数
- router-link一次
- 获取的时候一次
- path方式配置参数
- router-link一次
- 规则配置的时候声明位置
- 获取的时候一次
- 总结书写代码注意事项
- path方式需要在路由规则中声明位置
7. vue-router中的对象
$route
路由信息对象,只读对象$router
路由操作对象,只写对象
8. 路由嵌套
- 市面上所谓的用单页面应用框架开发多页应用
- 潜逃路由
- 案例
- 进入我的主页显示:电影/歌曲
- 代码思想
- 1.
router-view
的细分router-view
第一层,包含一个router-view
- 2. 每一个坑挖好了,要对应单独的组件
- 1.
9. 知识点介绍
- 路由
meta
元素数据 ->meta
是对于路由规则是否需要验证权限的配置- 路由对象中和name属性同级
{meta:{isChecked:true}}
- 路由对象中和name属性同级
- 路由钩子 -> 权限控制的函数执行时期
- 每次路由匹配后,渲染组件到
router-view
之前 router.beforeEach(function(to,from,next){ })
- 每次路由匹配后,渲染组件到
10. 编程导航
- 1. 跳转到指定的锚点,并显示页面
this.$router.push({name:'xxx',query:{id:1},params:{name:'abc'}})
- 2. 配置规则
{name:'xxx',path:'/xxx/:name'}
- 3. 根据历史记录前进后退
this.$router.go(-1|1)
- 1代表前进,-1代表后退
vue.js及项目实战[笔记]— 03 vue.js插件的更多相关文章
- vue.js及项目实战[笔记]— 01 vue.js
一. vue基础 1. 历史介绍 angular 09年,年份较早,一开始大家是拒绝的 react 2013年,用户体验较好,直接拉到一堆粉丝 vue 2014年,用户体验较好 前端框架与库的区别 j ...
- vue.js及项目实战[笔记]— 02 vue.js基础
一. 基础 1. 注册全局组件 应用场景:多出使用的公共性能组件,就可以注册成全局组件,减少冗余代码 全局APIVue.component('组件名','组件对象') 2.附加功能:过滤器&监 ...
- vue.js及项目实战[笔记]— 05 WebPack
一. 历史介绍 1. 规范 AMD Commonjs||CMD UMD 参考:认识AMD.CMD.UMD.CommonJS 2. 工具 npm bower webpack browserify 参考: ...
- vue.js及项目实战[笔记]— 04 axios
一. axios 1. 基本使用 axios.method('url',[,...data],options) .then(function(res){ }) .catch(function(err) ...
- Unity3D项目实战笔记(10):Unity3D编译IPA的PostEvents–节约时间利器
最近,SDK支付等接入差不多了,就从Unity3D生成IPA (企业版License), 然,需要手动执行的PostEvents竟然多大10项+, 这些我默默的承受了1周时间,每次约浪费20分钟-额外 ...
- Unity3D项目实战笔记(5):延时功能的几种实现
我所做过的系统,分单机版系统(2005年).CS系统(2010年).实时系统(2015年),各个系统均有“延时”功能:定时调度的: 本博客说的是实时系统中的延时功能(基于Unity3D游戏引擎). 在 ...
- Spring Boot +Vue 项目实战笔记(一):使用 CLI 搭建 Vue.js 项目
前言 从这篇文章开始,就进入真正的实践了. 在前端项目开发中,我们可以根据实际情况不同程度地使用 Vue.利用 Vue CLI(或写成 vue-cli,即 Vue 脚手架)搭建出来的项目,是最能体现 ...
- vue.js+koa2项目实战(一)创建项目和elementUI配置
前端采用vuex+element-ui: 后端采用koa2+restfulAPI+sequlize: (一)项目介绍 宠物社区 1.社区 2.好友 3.说说 4.宠粮 5.健康 (二)项目框架 1.V ...
- Spring Boot +Vue 项目实战笔记(二):前后端结合测试(登录页面开发)
前言:关于开发环境 每位 Coder 都有自己偏好的开发工具,从大的方面划分主要有文本编辑器流和 IDE 流两种,我有一段时间也喜欢用编辑器(Sublime Text.Vim),但对我来说开发效率确实 ...
随机推荐
- SpringMVC框架三:参数绑定
这篇文章整合了SpringMVC和MyBatis: https://www.cnblogs.com/xuyiqing/p/9419144.html 接下来看看参数绑定: 默认Conrtroller可以 ...
- CI-CD平台搭建过程整理
Coding ---> gitlab --->jenkins ---> maven(nexus) ---> 编译构建成image ---> Harbor ---> ...
- MQTT入门篇
物联网(Internet of Things,IoT)最近曝光率越来越高.虽然HTTP是网页的事实标准,不过机器之间(Machine-to-Machine,M2M)的大规模沟通需要不同的模式:之前的请 ...
- Python - 安装并配置Anaconda环境
1- 简介 官网:https://www.anaconda.com/ Anaconda是一个用于科学计算的Python发行版,适用于数据分析的Python工具,也可以用在大数据和人工智能领域. 支持 ...
- 告诉你,Spring Boot 真是个牛逼货!
现在 Spring Boot 非常火,各种技术文章,各种付费教程,多如牛毛,可能还有些不知道 Spring Boot 的,那它到底是什么呢?有什么用?今天给大家详细介绍一下. Spring Boot ...
- ajax实现异步前后台交互,模拟百度搜索框智能提示
1.什么是异步?在传统的网站项目中,填写一堆数据,最后点击提交,在点击提交的这一刻才实现数据提交,前后台交互.在你点击提交之前数据是没有提交到后台的.这样就会造成很大的不便.比如,我填了一大堆数据,结 ...
- Navicat 连接Oracle的教程以及注意事项
今天使用Navicat 连接Oracle时晕倒了一些坑,特此记录一下! 楼主就是64位win10系统,安装的Navicat是64位的,刚开始配置32位的oci.配置后连接还是提示“Connot loa ...
- shell变量定义与数组-1
1.查看系统所有shell和默认shell 查看系统所有的shell: cat /etc/shells 查看系统默认shell: echo $SHELL 2.第一个shell脚本,打印字符串Hello ...
- Quartz使用记录总结
Quartz是一个任务调度框架,最近在项目中有用到,所以做个记录总结. 一.主要元素 Scheduler:调度器,控制任务的调度,将JobDetail和Trigger注册到Scheduler加以控制. ...
- Spring Boot (四)模板引擎Thymeleaf集成
一.Thymeleaf介绍 Thymeleaf是一种Java XML / XHTML / HTML5模板引擎,可以在Web和非Web环境中使用.它更适合在基于MVC的Web应用程序的视图层提供XHTM ...