最近开发公司vue前端项目,做一下笔记,偶尔上来查漏补缺

组件操作:

使用flag标识符结合v-ifv-else切换组件

  1. 页面结构:

<div id="app">
<input type="button" value="toggle" @click="flag=!flag">
<my-com1 v-if="flag"></my-com1>
<my-com2 v-else="flag"></my-com2>
</div>
  1. Vue实例定义:

<script>
Vue.component('myCom1', {
template: '<h3>奔波霸</h3>'
})

Vue.component('myCom2', {
template: '<h3>霸波奔</h3>'
})

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {
flag: true
},
methods: {}
});
</script>

使用:is属性来切换不同的子组件,并添加切换动画

  1. 组件实例定义方式:

  // 登录组件
const login = Vue.extend({
template: `<div>
<h3>登录组件</h3>
</div>`
});
Vue.component('login', login);

// 注册组件
const register = Vue.extend({
template: `<div>
<h3>注册组件</h3>
</div>`
});
Vue.component('register', register);

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: { comName: 'login' },
methods: {}
});
  1. 使用component标签,来引用组件,并通过:is属性来指定要加载的组件:

 <div id="app">
<a href="#" @click.prevent="comName='login'">登录</a>
<a href="#" @click.prevent="comName='register'">注册</a>
<hr>
<transition mode="out-in">
<component :is="comName"></component>
</transition>
</div>
  1. 添加切换样式:

 <style>
.v-enter,
.v-leave-to {
opacity: ;
transform: translateX(30px);
}

.v-enter-active,
.v-leave-active {
position: absolute;
transition: all .3s ease;
}

h3{
margin: ;
}
</style>

父组件向子组件传值

  1. 组件实例定义方式,注意:一定要使用props属性来定义父组件传递过来的数据

<script>
// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {
msg: '这是父组件中的消息'
},
components: {
son: {
template: '<h1>这是子组件 --- {{finfo}}</h1>',
props: ['finfo']
}
}
});
</script>
  1. 使用v-bind或简化指令,将数据传递到子组件中:

<div id="app">
<son :finfo="msg"></son>
</div>

子组件向父组件传值

  1. 原理:父组件将方法的引用,传递到子组件内部,子组件在内部调用父组件传递过来的方法,同时把要发送给父组件的数据,在调用方法的时候当作参数传递进去;

  2. 父组件将方法的引用传递给子组件,其中,getMsg是父组件中methods中定义的方法名称,func是子组件调用传递过来方法时候的方法名称

<son @func="getMsg"></son>
  1. 子组件内部通过this.$emit('方法名', 要传递的数据)方式,来调用父组件中的方法,同时把数据传递给父组件使用

<div id="app">
<!-- 引用父组件 -->
<son @func="getMsg"></son>

<!-- 组件模板定义 -->
<script type="x-template" id="son">
<div>
<input type="button" value="向父组件传值" @click="sendMsg" />
</div>
</script>
</div>

<script>
// 子组件的定义方式
Vue.component('son', {
template: '#son', // 组件模板Id
methods: {
sendMsg() { // 按钮的点击事件
this.$emit('func', 'OK'); // 调用父组件传递过来的方法,同时把数据传递出去
}
}
});

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {},
methods: {
getMsg(val){ // 子组件中,通过 this.$emit() 实际调用的方法,在此进行定义
alert(val);
}
}
});
</script>

vue-router

  1. 导入 vue-router 组件类库:

<!-- . 导入 vue-router 组件类库 -->
<script src="./lib/vue-router-2.7.0.js"></script>
  1. 使用 router-link 组件来导航

<!-- . 使用 router-link 组件来导航 -->
<router-link to="/login">登录</router-link>
<router-link to="/register">注册</router-link>
  1. 使用 router-view 组件来显示匹配到的组件

<!-- . 使用 router-view 组件来显示匹配到的组件 -->
<router-view></router-view>
  1. 创建使用Vue.extend创建组件

    // 4.1 使用 Vue.extend 来创建登录组件
var login = Vue.extend({
template: '<h1>登录组件</h1>'
});

// 4.2 使用 Vue.extend 来创建注册组件
var register = Vue.extend({
template: '<h1>注册组件</h1>'
});
  1. 创建一个路由 router 实例,通过 routers 属性来定义路由匹配规则

// 5. 创建一个路由 router 实例,通过 routers 属性来定义路由匹配规则
var router = new VueRouter({
routes: [
{ path: '/login', component: login },
{ path: '/register', component: register }
]
});
  1. 使用 router 属性来使用路由规则

// 6. 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
router: router // 使用 router 属性来使用路由规则
});

设置路由高亮

设置路由切换动效

在路由规则中定义参数

  1. 在规则中定义参数:

{ path: '/register/:id', component: register }
  1. 通过 this.$route.params来获取路由中的参数:

var register = Vue.extend({
template: '<h1>注册组件 --- {{this.$route.params.id}}</h1>'
});
children 属性实现路由嵌套
 <div id="app">
<router-link to="/account">Account</router-link>

<router-view></router-view>
</div>

<script>
// 父路由中的组件
const account = Vue.extend({
template: `<div>
这是account组件
<router-link to="/account/login">login</router-link> |
<router-link to="/account/register">register</router-link>
<router-view></router-view>
</div>`
});

// 子路由中的 login 组件
const login = Vue.extend({
template: '<div>登录组件</div>'
});

// 子路由中的 register 组件
const register = Vue.extend({
template: '<div>注册组件</div>'
});

// 路由实例
var router = new VueRouter({
routes: [
{ path: '/', redirect: '/account/login' }, // 使用 redirect 实现路由重定向
{
path: '/account',
component: account,
children: [ // 通过 children 数组属性,来实现路由的嵌套
{ path: 'login', component: login }, // 注意,子路由的开头位置,不要加 / 路径符
{ path: 'register', component: register }
]
}
]
});

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {},
methods: {},
components: {
account
},
router: router
});
</script>

最新文章

  1. 小谈Java里的线程
  2. vc6编译apache遇到的问题
  3. springboot hessian
  4. thinkphp- 许愿墙-1
  5. Node.js 快速了解
  6. 九度oj 1541 二叉树
  7. Oracle中常见的33个等待事件小结
  8. Vb.Net Xml文档格式化
  9. POJ 3189 Steady Cow Assignment【网络流】
  10. 去掉删除discuz x3.2 的-Powered by Discuz!
  11. nginx 详解反向代理负载均衡
  12. j2ee之监听页面请求
  13. jquery 1.7.2源码解析(二)构造jquery对象
  14. 潭州课堂25班:Ph201805201 WEB 之 CSS 第二课 (课堂笔记)
  15. 利用System.Uri转URL为绝对地址
  16. math、numpy、pandas NaN 判断
  17. SignalR简介
  18. 【刷题】LOJ 6001 「网络流 24 题」太空飞行计划
  19. HTML5学习笔记(十):CSS常用操作
  20. apache配置修改

热门文章

  1. Asterisk 的安全性
  2. H3 android 系统编译
  3. gcc 库路径里同时有相同文件名的动态库和静态库
  4. kbmmw 5.06.00 beta 发布
  5. kbmmw 的HTTPSmartService入门
  6. 算法工程师B
  7. 2019.01.21 NOIP训练 ak树(点分治)
  8. 2018.11.06 洛谷P1941 飞扬的小鸟(背包)
  9. java Concurrent包学习笔记(六):Exchanger
  10. Linux 的虚拟文件系统(强烈推荐)