本文将详细介绍Vue单文件组件

概述
在很多 Vue 项目中,使用 Vue.component 来定义全局组件,紧接着用 new Vue({ el: '#container '}) 在每个页面内指定一个容器元素。
这种方式在很多中小规模的项目中运作的很好,在这些项目里 JavaScript 只被用来加强特定的视图。但当在更复杂的项目中,或者前端完全由 JavaScript 驱动的时候,下面这些缺点将变得非常明显:
1、全局定义 (Global definitions) 强制要求每个 component 中的命名不得重复
2、字符串模板 (String templates) 缺乏语法高亮,在 HTML 有多行的时候,需要用到丑陋的 \
3、不支持 CSS (No CSS support) 意味着当 HTML 和 JavaScript 组件化时,CSS 明显被遗漏
4、没有构建步骤 (No build step) 限制只能使用 HTML 和 ES5 JavaScript, 而不能使用预处理器,如 Pug (formerly Jade) 和 Babel
文件扩展名为 .vue 的 single-file components(单文件组件) 为以上所有问题提供了解决方法,并且还可以使用 Webpack 或 Browserify 等构建工具
下面是一个文件名为 Hello.vue 的简单实例:
通过单文件组合,现在我们获得:
1、完整语法高亮
2、CommonJS 模块
3、组件化的 CSS
还可以使用预处理器来构建简洁和功能更丰富的组件,比如 Pug,Babel (with ES2015 modules),和 Stylus。
这些特定的语言只是例子,可以只是简单地使用 Babel,TypeScript,SCSS,PostCSS - 或者其他任何能够帮助提高生产力的预处理器。如果搭配vue-loader使用Webpack,它也是把CSS Modules当作第一公民对待
【关注点分离】
一个重要的事情值得注意,关注点分离不等于文件类型分离。在现代 UI 开发中,已经发现相比于把代码库分离成三个大的层次并将其相互交织起来,把它们划分为松散耦合的组件再将其组合起来更合理一些。在一个组件里,其模板、逻辑和样式是内部耦合的,并且把它们搭配在一起实际上使得组件更加内聚且更可维护。
即便不喜欢单文件组件,仍然可以把 JavaScript、CSS 分离成独立的文件然后做到热重载和预编译
<!-- my-component.vue --> <template> <div>This will be pre-compiled</div> </template> <script src="./my-component.js"></script> <style src="./my-component.css"></style>
起步
有了 .vue 组件,就进入了高级 JavaScript 应用领域
最好参考 webpack-simple。只要遵循指示,就能很快地运行一个用到 .vue 组件,ES2015 和 热重载 (hot-reloading) 的 Vue 项目。这个模板使用 Webpack,一个能将多个模块打包成最终应用的模块打包工具
在 Webpack 中,每个模块被打包到 bundle 之前都由一个相应的 “loader” 来转换,Vue 也提供 vue-loader 插件来执行 .vue 单文件组件 的转换。这个 webpack-simple 模板已经为你准备好了所有的东西
无论更钟情Webpack或是Browserify,简单的或更复杂的项目都可参考一些文档模板。浏览github.com/vuejs-templates,找到需要的部分,然后参考 README 中的说明,使用 vue-cli 工具生成新的项目
模板中使用 Webpack,一个模块加载器加载多个模块然后构建成最终应用
以上这篇基于Vue单文件组件详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
# vue
# 单文件组件
# Vuejs 单文件组件实例详解
# vuejs 单文件组件.vue 文件的使用
# 解决vue 单文件组件中样式加载问题
# Vue单文件组件的如何使用方式介绍
# 详解Vue 单文件组件的三种写法
# vue单文件组件无法获取$refs的问题
# 轻松学Vue组件之单文件组件
# 还可以
# 多个
# 给大家
# 是一个
# 加载
# 很好
# 就能
# 为你
# 不喜欢
# 而不
# 有多
# 希望能
# 详细介绍
# 不支持
# 一个重要
# 在这些
# 这篇
# 能将
# 或者其他
# 解决方法
相关文章:
七夕网站制作视频,七夕大促活动怎么报名?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
如何在阿里云部署织梦网站?
桂林网站制作公司有哪些,桂林马拉松怎么报名?
广平建站公司哪家专业可靠?如何选择?
如何解决ASP生成WAP建站中文乱码问题?
枣阳网站制作,阳新火车站打的到仙岛湖多少钱?
如何在IIS管理器中快速创建并配置网站?
微信h5制作网站有哪些,免费微信H5页面制作工具?
广东专业制作网站有哪些,广东省能源集团有限公司官网?
如何通过多用户协作模板快速搭建高效企业网站?
如何通过NAT技术实现内网高效建站?
家具网站制作软件,家具厂怎么跑业务?
如何有效防御Web建站篡改攻击?
如何快速搭建安全的FTP站点?
如何快速查询网站的真实建站时间?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
网站制作的方法有哪些,如何将自己制作的网站发布到网上?
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
建站之星安装后如何配置SEO及设计样式?
如何快速搭建高效可靠的建站解决方案?
台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?
大同网页,大同瑞慈医院官网?
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
如何高效搭建专业期货交易平台网站?
广州美橙建站如何快速搭建多端合一网站?
如何选择PHP开源工具快速搭建网站?
网站制作免费,什么网站能看正片电影?
历史网站制作软件,华为如何找回被删除的网站?
建站主机系统SEO优化与智能配置核心关键词操作指南
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
c# F# 的 MailboxProcessor 和 C# 的 Actor 模型
招贴海报怎么做,什么是海报招贴?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
怎么将XML数据可视化 D3.js加载XML
建站之星安装路径如何正确选择及配置?
,南京靠谱的征婚网站?
常州企业建站如何选择最佳模板?
建站之星在线客服如何快速接入解答?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
建站主机选购指南与交易推荐:核心配置解析
如何通过西部数码建站助手快速创建专业网站?
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
自助网站制作软件,个人如何自助建网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。