vue的基础整理

vue Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统,核心思想是:数据驱动、组件系统。 Vue.js 的目标是通过尽

vue

Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统,核心思想是:数据驱动、组件系统。

Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

特点:mvvm m=mvc module 模型 v=view 视图 c=controller 控制器

vue的指令

v-model:数据的双向绑定
data :返回对象用 return
v-for :循环 格式 v-for="字段名 in(of) 数组json"
v-show: 显示 隐藏 传递的值为布尔值 true false 默认为false
v-if :显示与隐藏 和v-show对比的区别 就是是否删除dom节点 默认值为false;控制一个元素是否显示(会对DOM进行创建和删除操作 有较高的切换性能消耗)
v-else-if: 必须和v-if连用
v-else :必须和v-if连用 不能单独使用 否则报错 模板编译错误
v-bind :动态绑定 作用: 及时对页面的数据进行更改 简写" : " 三种绑定方法 1、对象型'{red:isred}'2、三目型 'isred?"red":"blue"' 3、数组型 '[{red:"isred"},{blue:"isblue"}]'
v-on :绑定事件 函数必须写在methods里面
@click 快捷方法
v-on @ 事件修饰符:
 .stop:等同于JavaScript中的event.stopPropagation(),防止事件冒泡
 .prevent:等同于JavaScript中的event.preventDefault(),防止执行预设的行为(如果事件可取消,则取消该事件,而不停止事件的进一步传播)
 .capture:与事件冒泡的方向相反,事件捕获由外到内
 .self:只会触发自己范围内的事件,不包含子元素
 *.once:只会触发一次
v-text: 解析文本
v-html: 解析html标签
v-once: 进入页面时 只渲染一次 不在进行渲染
v-cloak: 防止闪烁
v-pre :把标签内部的元素原位输出

局部组件

var app = new Vue({

el:'#app',

//定义局部组件,这里可以定义多个局部组件

component:{

//组件的名字

'Navbar':{

//组件的内容

template:'<ul><li>首页</li><li>学员管理</li></ul>'

}

}

})

<div id='app'>

<Navbar></Nacbar>

</div>

}

全局组件

定义全局组件

vue.component('Navbar',{

template:'<ul><li>首页</li><li>学员管理</li><li>讲师管理</li></ul>'

})

<div id='app'>

<Navbar></Navbar>

</div>

<script src="vue.min.js"></script>

<script src='components/Navbar.js'></script>

<script>

var app = new Vue({

el:'#app'

})

</script>

路由

vue.js路由允许我们通过不同的URL访问不同的内容.

通过Vue.js可以实现多视图的单页Web应用.

vue.js路由需要载入vue-router库.

引入js库

<script src='vue.min.js'></script>

<script src='vue-router.min.js'></script>

编写html

<div id='app'> 

<h1>Hello App!</h1>

<p>

<!-- 使用 router-link 组件来导航. -->

<!-- 通过传入 `to` 属性指定链接. -->

<!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->

<router-link to='/'>首页</router-link>

<router-link to='/student'>会员管理</router-link>

<router-link to='/teacher'>讲师管理</router-link>

</p>

<!-- 路由出口 -->

<!-- 路由匹配到的组件将渲染在这里 -->

<router-view></router-view>

</div>

编写js

<script>

// 1. 定义(路由)组件。

// 可以从其他文件 import 进来

const Welcome = { template: '<div>欢迎</div>' }

const Student = { template: '<div>student list</div>' }

const Teacher = { template: '<div>teacher list</div>' }

// 2. 定义路由

// 每个路由应该映射一个组件。

const routes = [

{ path: '/', redirect: '/welcome' }, 

//设置默认指向的路径

{ path: '/welcome', component: Welcome },

{ path: '/student', component: Student },

{ path: '/teacher', component: Teacher }

]

// 3. 创建 router 实例,然后传 `routes` 配置const router = new VueRouter({routes // (缩写)相当于 routes: routes})

// 4. 创建和挂载根实例。

// 从而让整个应用都有路由功能const app = new Vue({el: '#app',router})

// 现在,应用已经启动了!

</script>

 

标签: 标签 首页 绑定