文档章节

Vue.js、vue安装步骤、单文件组件、模板指令

娇娇jojo
 娇娇jojo
发布于 2017/09/05 14:54
字数 1128
阅读 234
收藏 8

作者:汪娇娇

时间:2017年8月30日

1、npm淘宝镜像

直接用npm安装vue-cli会特别慢,在安装vue-cli之前可以先安装一个淘宝镜像。之后的安装命令还是和npm一样,只不过把npm改成cnpm,但速度已经不是一个等级的了,嗖嗖嗖嗖~~~

npm install -g cnpm --registry=https://registry.npm.taobao.org

2、安装vue项目步骤

轻轻松松下面几步,就可以创建并启动一个带热重载、保存时静态检查以及可用于生产环境的构建配置的项目啦。

# 全局安装 vue-cli
$ cnpm install --global vue-cli
# 创建一个基于 webpack 模板的新项目(项目名称:vue-webpack)
$ vue init webpack vue-webpack
# 安装依赖,走你
$ cd my-project
$ cnpm install
# 运行项目
$ cnpm run dev

生成好的目录结构如下:

3、vue组件

下图是一个单文件组件:

一个vue单文件组件的本质其实也就是html、css、js合成的一个文件,只不过必须用vue规定的格式来写,也就是在下图的template、script、style里面写相应的html、js和css:

那vue组件是怎么映射到页面的,看下图就明白了(借助webpack解析):

 

4、vue重要选项

下面介绍一下vue组件的重要选项(属性):

(1)data:vue对象的数据

new Vue({
    data: {
        a: 1
    }
})

<p> {{ a }} </p>

(2)methods:vue对象的方法

new Vue({
    data: {
        a: 1
    },
    methods: {
        doSomething: function() {
            console.log(this.a);
        }
    }
})

(3)watch:设置了对象监听的方法

监听你想监听的任何数据,下图监听数据 “a” 的变化,可以打印出变化之前的值和现在的值。

new Vue({
    data: {
        a: 1
    },
    methods: {
        doSomething: function() {
            console.log(this.a);
        }
    },
    watch: {
        'a': function(val, oldVal) {
            console.log(val.oldVal);
        },
        //深度watch(适用于监听的数据结构比较复杂,例如 c = { list: "apple", isFinished: true} ,那监听c的变化就建议选择深度watch,而且必须当deep为true时生效,false时不生效(例如,将isFinished改为false,结果还是true))
        c: {
           handler: function (val, oldVal) { /* ... */ },
           deep: true
        }
    }
})

 

5、模板指令

Vue对象里的设置通过html指令进行关联(也就是双向数据绑定),重要指令包括:

(1)渲染数据:v-text、v-html、{{}}

<P> {{ a }} </p>
<P v-text="a"></p>
<P v-html="a"></p>

new Vue({
    data: {
        a: 1
    }
})

{{}}是v-text的一个简写。

v-textv-html的区别:v-text会将html标签escape成文本,而v-html不会。

(2)控制显隐:v-if、v-show

<p v-if="isShow"></p>    //直接不渲染
<p v-show="isShow"></p>  //渲染这个dom元素,通过css的display属性来控制

new Vue({
    data: {
        isShow: true
    }
})

(3)循环渲染:v-for

<ul>
    <li v-for='item in items'>
        <p v-text='item.label'></p>
    </li>
</ul>

data: {
    items: [
        {
            label: 'apple'
        },
        {
            label: 'banana'
        }
    ]
}


(4)绑定事件:v-on

<button v-on:click="doThis"></button>
<button @click="doThis"></button>   //简写@

methods: {
    doThis: function someThing) {
        
    }
}

(5)绑定属性:v-bind

<img v-bind:src="imageSrc">   //字符串

<div :class="{ red: isRed }"></div>  //布尔值
<div :class="[classA, classB]"></div>   //字符串
<div :class="[classA, { classB: isB, classC: isC }]"></div>

 

6、如何划分组件

简单的页面还好,一旦涉及功能性复杂的大型网站,那就需要好好规划规划组件的划分了,那组件到底要怎么划分呢,还是需要按照什么原则去划分?

虽然没有强烈的规则去要求,但还是有原则可依的。我觉得组件大致可以划分为2类,也就是功能模块页面区域,大家可以根据自己的情况去划分,下面的划分仅供大家参考:

  • 功能模块:select、pagenation...
  • 页面区域:header,footer,sidebar...

(1)components

那么问题来了,划分组件之后,这些组件之间如何相互调用呢?

components君正式登场!!!

App.vue是组件入口,footer.vue和header.vue是组件。

(2)props

相互调用的问题解决了,接下来说说组件之间的通信 - props

下面是父组件向子组件传递信息msg,只有用props注册了msg之后,子组件里才可以获取到msg的值,否则,无论传什么值,子组件都是没法取到的。

那子组件传信息给父组件呢?

那么子组件就可以直接使用$on或者$emit触发事件来传信息给父组件,下图是$emit的实例。

//父组件App.vue(自定义child-tell-me事件,触发listenToMyBoy方法)
<header-a v-on:child-tell-me='listenToMyBoy'></header-a>

methods: {
	listenToMyBoy: function(msg){
		this.childWords = msg;
	}
}
//子组件(点击按钮将msg发送给父组件)
<button @click="onClickMe">Click!</button>

export default {
	data () {
		return {
			msg: "Hello Vue"
		}
	},
	methods: {
		onClickMe: function(){
			this.$emit("child-tell-me",this.msg);
		}
	}
}

 

© 著作权归作者所有

共有 人打赏支持
娇娇jojo
粉丝 180
博文 59
码字总数 64429
作品 0
海淀
私信 提问
加载中

评论(1)

DoubleKang
DoubleKang
666
前端框架之Vue.js 库的使用

vue.js简介 Vue.js是前端三大新框架:Angular.js、React.js、Vue.js之一,Vue.js目前的使用和关注程度在三大框架中稍微胜出,并且它的热度还在递增。 Vue.js可以作为一个js库来使用,也可以用...

玄学酱
06/22
0
0
vue.js快速入门。

什么是Vue.js   Vue.js是一个构建数据驱动的web界面的库。技术上,它重点集中在MVVM模式的ViewModel层,因此它非常容易学习,非常容易与其它库或已有项目整合。   Vue.js的目标是通过尽可...

笔阁
2015/12/23
10K
2
构建你的第一个Vue.js组件

我记得当时我拿起CakePHP,我很喜欢,开始使用它是多么容易。这些文档不仅结构合理,详尽无遗,而且用户友好。多年以后,这正是我在Vue.js中感受到的。然而,与Cake相比,Vue文档仍然缺少一件...

Swiftly
07/17
0
0
Vue.js 新手入门教程之环境搭建(一)

本文相关引用来自Vue官网 https://cn.vuejs.org/ 作为一个Java后端程序员觉得有必要了解一下当前流行的Vue框架(PS:公司目前后台管理系统前端用的是老掉牙的easyui~囧),是时候更新换代了。...

青小城
10/19
0
0
Vue.js入门之工程目录介绍

Vue 是一套用于构建用户界面的渐进式框架,与其它大型的页面框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另...

异步社区
05/22
0
0

没有更多内容

加载失败,请刷新页面

加载更多

java框架学习日志-7(静态代理和JDK代理)

静态代理 我们平时去餐厅吃饭,不是直接告诉厨师做什么菜的,而是先告诉服务员点什么菜,然后由服务员传到给厨师,相当于服务员是厨师的代理,我们通过代理让厨师炒菜,这就是代理模式。代理...

白话
今天
14
0
Flink Window

1.Flink窗口 Window Assigner分配器。 窗口可以是时间驱动的(Time Window,例如:每30秒钟),也可以是数据驱动的(Count Window,例如:每一百个元素)。 一种经典的窗口分类可以分成: 翻...

满小茂
今天
9
0
my.ini

1

architect刘源源
今天
10
0
docker dns

There is a opensource application that solves this issue, it's called DNS Proxy Server It's a DNS server that solves containers hostnames, if could not found a hostname that mat......

kut
今天
10
0
寻找数学的广度——《这才是数学》读书笔记2700字

寻找数学的广度——《这才是数学》读书笔记2700字: 文|程哲。数学学习方式之广:国内外数学教育方面的专家,进行了很多种不同的数学学习方式尝试,如数学绘本、数学游戏、数学实验、数学步道...

原创小博客
今天
21
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部