摘要:在这个组件里面有一些链接列表,和,这些列表直接使用编写按照传统的写法,如果我们需要往里面添加链接的时候,每次我们都得添加和标签。所以修改如下这样我们就把数据和视图分开了,模板里面的代码也简洁了很多,不再需要写很多重复的代码。
Vue 的官方文档 对 Vue 介绍非常详细,但官方文档使用在 HTML 中引入 vue 的方式进行讲解,而实际项目中一般使用脚手架如 vue-cli 初始化项目。以至于刚看完文档时,却依旧不能立即立即 vue-cli 创建的项目代码。所以本文 vue-cli 构建的项目为基础,详细解释其代码及对应的概念,并进行简单的实践。
命令行工具 安装 vue-cli 并初始化项目本文的代码在 https://github.com/nodejh/vue2-tutorials/tree/master/01.QuickStart
首先要全局安装 vue-cl:
$ npm install --global vue-cli
然后使用 vue-cli 初始化一个基于 webpack 模板的新项目,除了 Install vue-router? 选 N (No),其余都可以直接回车选 Y (Yes),因为我们暂时不会讲到 vue-router:
$ vue init webpack demo ? Project name demo ? Project description A Vue.js project ? Author nodejh安装依赖? Vue build standalone ? Install vue-router? No ? Use ESLint to lint your code? Yes ? Pick an ESLint preset Standard ? Setup unit tests with Karma + Mocha? Yes ? Setup e2e tests with Nightwatch? Yes
$ cd demo $ npm install $ npm run dev
然后打开浏览器,输入 http://localhost:8080 就能看到界面。
接下来分析一下代码。
代码分析项目目录结构如下:
├── README.md ├── build # 编译项目的配置文件目录 ├── config # 配置文件目录 ├── src # 项目主要代码目录 ├── static # 静态资源 ├── test # 测试文件目录
开发阶段的主要代码都在 src 目录中编写,vue-cli 默认生成了一些代码:
src ├── App.vue ├── assets │ └── logo.png ├── components │ └── Hello.vue └── main.js
可以发现,代码的后缀名有两种:
.js JS 文件
.vue Vue 组件,里面定义了 Vue 实例、模板、样式等。需要由 webpack 等工具来转换为 js 代码
接下来会逐一解释这些文件及代码。
main.jsmain.js 是项目的入口文件,也是 webpack 打包的入口文件。里面最代码很少,主要就是通过 new Vue() 创建 Vue 实例:
new Vue({ el: "#app", template: "", components: { App }, });
每个 Vue.js 应用都是通过构造函数 Vue 创建一个 Vue 的根实例启动的。
在实例化 Vue 时,传入一个了一个对象,对象包含以下几个选项。
elel 的值是 Vue 实例的挂载目标,这里是 #app,也就是 demo/index.html 中 id="app" 这个元素:
el 必须是一个已存在的元素。
api/#el
components在说 template 之前,先来看看 components 属性。
components: { App } 等价于 components: { App: App },是一个包含了对 Vue 实例可见的组件的哈希表。只有在 components 里面列出来的组件,才可以在 template 里面使用。
如果我们把 components: { App } 改为 components: { App } 改为 components: { MyApp: App },那么在 template 里面就需要这样使用:template: "
由于 HTML 标签不区分大小写,所以 components 里面的驼峰命名会自动转换为短横线。详见 camelCase vs. kebab-case
templatetemplate 就是挂载到页面的模板。
这里的值是
new Vue({ el: "#app", // 这里的就是 components 属性的值 App template: " ", components: { App }, });
所以这段代码的含义就是,将
src/App.vue 是一个典型的单文件组件。实际在项目中,我们写的基本都是组件,再根据需要用组件组成页面,这其实就是组件化。组件与组件之间相互独立,项目结构更加清晰,也更有利于维护。
一个组件里面封装了 HTML、CSS 和 JS,有自己独立的样式和逻辑。
就是组件中的模板,模板的代码都在 标签中,除
为什么模板中能使用 hello 这个组件呢?
这是因为 标签里面定义了 Hello(首字母大写)这个组件:
import Hello from "./components/Hello" export default { name: "app", components: { // Hello 组件,即 ./components/Hello 的一个引用 Hello } }
这里 components 属性的含义,在之前已经提到过了,只有在 components 里面列出来的组件,才能被模板使用。这里列出了 Hello 这个组件,所以在 中我们可以使用
而 components 属性里面的 Hello,则是 ./components/Hello 这个组件的一个引用:
import Hello from "./components/Hello"
最后就是 标签,里面就是普通的 CSS 了。
src/components/Hello.vue最后再来看看 src/components/Hello.vue 这个组件的代码。
基本跟 src/App.vue 是一样的,除了下面这两个地方之外:
{{ msg }}
data () { return { msg: "Welcome to Your Vue.js App" } }
恭喜你!看到这里,我们就可以真正开始写代码了。
{{}} 是 Vue 的一个模板语法,文本插值。如上面的例子所示,我们在 data 里面定义一个对象,就可以在模板中通过 {{ }} 来访问。
data 虽然是一个函数,但它执行之后就等价于:
data: { msg: "Welcome to Your Vue.js App" }
当我们改变 msg 的值,在页面上渲染出来的数据也会改变。也就是数据和 DOM 绑定在了一起。
模板语法 插值 文本插值上面我们已经接触到了文本插值 {{}},{{ msg }} 将会被替代为对应数据对象上 msg 属性的值。无论何时,绑定的数据对象(即 data)上 msg 属性发生了改变,插值处的内容都会更新。
通过使用 v-once 指令,我们也能执行一次性地插值,当数据改变时,插值处的内容不会更新。但请留心这会影响到该节点上所有的数据绑定:
纯 HTMLThis will never change: {{ msg }}
双大括号会将数据解释为纯文本,而非 HTML 。为了输出真正的 HTML ,需要使用 v-html 指令:
这个 div 的内容将会被替换成为属性值 rawHtml,直接作为 HTML —— 数据绑定会被忽略。注意,你不能使用 v-html 来复合局部模板,因为 Vue 不是基于字符串的模板引擎。组件更适合担任 UI 重用与复合的基本单元。
JS 表达式你的站点上动态渲染的任意 HTML 可能会非常危险,因为它很容易导致 XSS 攻击。请只对可信内容使用 HTML 插值,绝不要对用户提供的内容插值。
{{}} 中也可以写 JS 表达式:
{{ number + 1 }} {{ ok ? "YES" : "NO" }} {{ message.split("").reverse().join("") }}指令
指令(Directives)是带有 v- 前缀的特殊属性。
v-bind{{}} 不能在 HTML 属性中使用。针对 HTML 属性需要使用 v-bind:
这对布尔值的属性也有效 —— 如果条件被求值为 false 的话该属性会被移除:
v-bind 也可以缩写:
v-on
v-on 用来监听 DOM 事件:
也可以缩写成下面这样:
v-ifNow you see me
这里 v-if 指令将根据表达式 seen 的值的真假来移除/插入
元素。
v-forv-for 指令可以绑定数组的数据来渲染一个项目列表:
实践
- {{ todo.text }}
让我们把目光回到 Hello.vue。在这个组件里面有一些链接列表, Essential Links 和 Ecosystem,这些列表直接使用 HTML 编写:
按照传统的写法,如果我们需要往里面添加链接的时候,每次我们都得添加 和 标签。思考两个问题:
添加几个链接还好,如果要添加非常非常多呢?难到要复制几十次 和 标签?
如果要动态改变链接列表呢?难道要使用 innerHTML 等方法修改 DOM?
聪明的你可能已经想到了,很明显不需要这么做,我们可以使用模板语法。将链接信息写到 Vue 的数据对象 data 里面,然后通过动态绑定的方式,将数据绑定到 DOM。
所以修改如下:
{{ msg }}
Essential Links
Ecosystem
这样我们就把数据和视图分开了,模板里面的代码也简洁了很多,不再需要写很多重复的代码。并且根据不同数据,我们也能展示出不同的 UI。
总结本文详细讲解了 vue-cli 初始化的项目代码,并且在讲解代码的过程中,介绍了构造 vue 对象的一些参数,以及 vue 的一些基本概念,比如模板语法中的插值和指令。最后通过修改代码对以上知识点进行实践。
相信看到了这里,你对如何使用 vue 写一个项目已经有了初步了解。当然,看完本文,可能还有很多概念理解不清楚,这时推荐去看一下 vue 的官方文档,这个时候再去看官方文档,应该就会轻松很多了。
https://github.com/nodejh/nodejh.github.io/issues/38
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/83874.html
摘要:前端日报精选了解中的全局对象和全局作用域张鑫旭鑫空间鑫生活子进程你应该知道的一切直出内存泄露问题的追查实践我他喵的到底要怎样才能在生产环境中用上模块化腾讯前端大会大咖说大咖干货,不再错过发布发布中文翻译在使用进行本地开发代码 2017-07-07 前端日报 精选 了解JS中的全局对象window.self和全局作用域self « 张鑫旭-鑫空间-鑫生活Node.js 子进程:你应该知道...
摘要:中文官网英文官网组织发出一个问题之后,不要暂时的离开电脑,如果没有把握先不要提问。珍惜每一次提问,感恩每一次反馈,每个人工作还是业余之外抽出的时间有限,充分准备好应有的资源之后再发问,有利于问题能够高效质量地得到解决。 Vue.js资源分享 更多资源请Star:https://github.com/maidishike... 文章转自:https://github.com/maid...
阅读 3694·2021-10-14 09:43
阅读 3293·2021-08-25 09:38
阅读 591·2019-08-30 15:55
阅读 1321·2019-08-30 13:05
阅读 2218·2019-08-29 16:05
阅读 473·2019-08-29 12:58
阅读 2771·2019-08-29 12:34
阅读 3224·2019-08-26 12:15