[译]为什么Vue不支持templateURL
Vue的新用户最常问的一个问题,特别是以前使用Angular的用户,是“我可以使用” templateURL吗?这个问题我回答过很多次,现在写一个统一回复。
在Angular中,templateURL或ng-include允许用户在运行时动态加载远程模板文件。作为Angular的内置功能,这似乎非常方便,但让我们重新考虑一下这种方式解决的问题。
是否有必要将html模板和js分离?
首先,它允许我们在一个单独的HTML文件中编写我们的模板。这在编辑器中给出了正确的语法高亮,这可能是为什么许多人喜欢这样做。但是分割您的JavaScript代码和模板真的是最好的方法吗?对于一个Vue.js组件,它的模板和它的JavaScript是紧密耦合的 - 实际上,如果事情只是在同一个文件,其实更简单。两个文件之间来回跳转的上下文切换实际上使得开发体验变得更糟。在概念上,组件是Vue.js应用程序的基本构建块,而不是模板。每个Vue.js模板都耦合到一个伴随的JavaScript上下文中 - 没有必要将它们分开。
本段大意是:将html模板和js分离,html有语法高亮、代码提示,开发体验好。但是因为html模板和js是紧密耦合的,把它们分开反倒不好。
templateURL会造成多次网络请求,导致加载缓慢
第二,因为templateURL在运行时通过Ajax加载模板,所以您不需要构建步骤来分割文件。这在开发过程中很方便,但是当您要将其部署到生产中时,这将会非常费力。在普遍支持HTTP / 2之前,HTTP请求的数量仍然是应用程序初始加载性能中最重要的因素。现在想象你使用templateURL对于您的应用程序中的每个组件 - 浏览器需要执行数十个HTTP请求,甚至可以显示任何内容!如果您不知道,大多数浏览器都会限制它可以对单个服务器执行的并行请求数。当您超过这个限制时,您的应用程序的初始渲染将受到浏览器等待的每次额外往返的影响。当然,有一些构建工具可以帮助您预先注册所有这些模板,$templateCache但是这给我们展示了一个构建步骤,实际上对于任何严重的前端开发来说是不可避免的。
正确姿势
那么,没有templateURL,我们如何处理开发体验问题?将模板作为内联JavaScript字符串编写是可怕的,伪造的模板<script type="x/template">也感觉像一个黑客。那么也许现在是游戏的一部分,并使用像Webpack或Browserify这样的正确的模块捆绑器。如果你以前从来没有处理过这件事,可能看起来很难,但是相信我是值得的。如果要构建任何大型和可维护的组件,则必须正确的模块化。更重要的是,您可以将Vue组件写入单个文件,具有适当的语法突出显示,以及自定义预处理器,热重新加载,ES2015默认情况下的自动翻译和范围CSS,从而使开发体验达到10倍以上的额外优势。
最后,Vue允许您懒惰加载您的组件,并且使用Webpack它很简单。虽然这只是一个问题,当你的初始捆绑是如此之大,以便你更好地分裂它分开。
综上,考虑使用组件,而不是模板。
[译]为什么Vue不支持templateURL的更多相关文章
- Vue为什么没有templateUrl
Why Vue.js doesn't support templateURL Vue.js为什么不支持templateUrl模式 原因 templateUrl使用ajax的方式在运行时加载templa ...
- 对于新版本的webstorm对vue的支持
webstorm 对于官方vue的支持,直到2017.1,这个版本,之后的版本不能直接安装vue插件,这时候就需要自己手动新建vue模板了
- vue不支持IE8的原因
当你把一个普通的 JavaScript 对象传给 Vue 实例的 data 选项,Vue 将遍历此对象所有的属性, 并使用 Object.defineProperty 把这些属性全部转为 getter ...
- vue 不支持 数组Array,只支持get set push,但是正是做tab的时候,用到splice,就都不好用了,最后用v-if,从新渲染 完美解决
vue 不支持 数组Array,只支持get set push,但是正是做tab的时候,用到splice,就都不好用了,最后用v-if,从新渲染 完美解决
- 填个小坑,Vue不支持IE8及以下,跨域ajax不支持IE9
这特么就尴尬了,说好的Vue支持IE8及以下的呢,引入jquery,测试IE个浏览器,IE9仍然显示不正常, 然而命令行测试Vue仍然存在, 数据回不来!数据回不来!数据回不来! 好吧 肉包子打狗$ ...
- atom中vue高亮支持emmet语法
vue高亮插件: language-vue 支持emmet语法: 文件>用户键盘映射>keymap.cson添加: 'atom-text-editor[data-grammar~=&quo ...
- [译]基于Vue.js的10个最佳UI框架,用于构建移动应用程序
原文查看10 Best Vue.js based UI Frameworks for Building Mobile Apps 如果您期待使用Vue.js构建移动应用程序,那么您可以选择许多可用的UI ...
- [译] 制作 Vue 3 的过程
原文链接: https://increment.com/frontend/making-vue-3 在过去的一年里,Vue 团队一直在研究 Vue.js 的下一个主要版本,我们希望在 2020 年上半 ...
- webstorm添加vue插件支持
现在已经有vue.js的插件啦,setting --> plugins 就可以咯 ------------------------------------------------ Mac端Web ...
随机推荐
- vld,Bounds Checker,memwatch,mtrace,valgrind,debug_new几种内存泄露检测工具的比较,Valgrind Cheatsheet
概述 内存泄漏(memory leak)指由于疏忽或错误造成程序未能释放已经不再使用的内存的情况,在大型的.复杂的应用程序中,内存泄漏是常见的问题.当以前分配的一片内存不再需要使用或无法访问时,但是却 ...
- 【TYVJ 五月图论专项有奖比赛】
最短路+TSP+最小生成树+倍增LCA+TreeDP 第一题 其实是个TSP问题(然而我没发现),但是关键点很少,只有5个,所以用dij+heap分别预处理出来这五个点为源的最短路…… 然后枚举起点 ...
- 【BZOJ】【2242】【SDOI2011】计算器
快速幂/扩展欧几里得/BSGS 经典好例题!! 三个问题三种算法…… 算法:白书(算法竞赛入门经典——训练指南)全有…… /************************************** ...
- c++学习之友元
最近工作好累呀,晚上总是失眠,自学c++的步骤都放慢了,本来之前看c++ primer的,结果这本书讲的太细节了,初学者不是很好把握.所以我又重新找了个教程,比较适合初学者.今天学习到友元函数和友元类 ...
- UVA 10012 How Big Is It?(暴力枚举)
How Big Is It? Ian's going to California, and he has to pack his things, including his collection ...
- iOS开发-简单的图片查看器
现在你只要拿着手机,不管你Android还是iOS,新闻类的App不可避免都有一个功能就是图片查看,做个专题,查看一下内容,App Store中也有专门针对图片浏览的App,鉴于目前所知有限,无法做到 ...
- jQuery多文件下载
文件下载是一个Web中非常常用的功能,不过你是做内部管理系统还是做面向公众的互联网公司都会遇到这个问题,对于下载一般有点实际开发经验的都会自己解决,上周弄了一下多文件下载,业务场景就是一条数据详细信息 ...
- Spring Security OAuth2 Demo
Spring Security OAuth2 Demo 项目使用的是MySql存储, 需要先创建以下表结构: CREATE SCHEMA IF NOT EXISTS `alan-oauth` DEFA ...
- 使用WPF来创建 Metro UI
当我第一次运行Zune时,我为这些美丽的UI所折服.当时就说这肯定不是用WPF做的,因为这些字体是如此的清晰而且UI反映的也非常快速..而且我从维基百科上也了解到Zune的第一个版本是2006年发布的 ...
- GoLang中如何使用多参数属性传参
我们常常因为传入的参数不确定而头疼不已,golang 为我们提供了接入多值参数用于解决这个问题.但是一般我们直接写已知代码即所有的值都知道一个一个塞进去就好了,但是绝大部分我们是得到用户的大量输入想通 ...