requirejs + vue 项目搭建详解


Posted in Javascript onJune 16, 2017

以前都是支持 司徒正美 的,毕竟咱们也是跟着 司徒正美 一起走进了前端的世界。所以一般MVVM都是用avalon的,当然也是考虑到项目需要支持IE6,7,8的考虑。当然在用的时候也有一些小坑和bug,都处理了。今年正美正好升级avalon2.0,加入虚拟dom的时候,不稳定了,就考试寻找其他的mvvm框架。

看了比较流行的一些框架,最后选择了vue。选择他的原因是 文档比较全,而且还有中文的(你懂的),生态圈比较好,有vux, vue-loader, vue-router ,组件化设计的也很好。

项目搭建的时候主要还是通过requirejs进行js模块加载(还没接触webpack,以前都是avalon+requirejs,习惯性思维了,下面就写写心路历程吧)

方案1,考虑能不能通过写个 requirejs 插件进行vue组件文件的加载

失败,主要是vue组件文件有template,script,style标签标签,主要通过requirejs,读取vue文件string文件进行正则分析在转换js, 有点舍近求远的方法,而且这种方式只能同域名ajax请求

方案2,通过编写gulp插件,将vue文件转换为可以通过requirejs加载的js文件。

这个方案是可行的,只是template,script,style信息,需要通过正则匹配,在动态载入到当前文档中,只是有些公用方法频繁调用。

所以加入了vueComment文件,把动态加入的方法整理在一起

define(['Vue'], function (Vue) {
  Vue.appendHTML = function (text) {
    document.body.insertAdjacentHTML('beforeEnd', text);
  };
  var style;
  var doc = document;
  Vue.appendCSS = function (text) {
    text = text + " ";
    if (!style) {
      var head = doc.getElementsByTagName("head")[0]; 
      var elms = head.getElementsByTagName("style"); 
      if (elms.length == 0) {
        if (doc.createStyleSheet) {
          doc.createStyleSheet(); 
        } else { 
          var tmp = doc.createElement('style');
          tmp.setAttribute("type", "text/css"); 
          head.appendChild(tmp); 
        }
        elms[0].setAttribute("media", "screen"); 
      } 
      style = elms[0];
    }
    if (style.styleSheet) {
      style.styleSheet.cssText += text; 
    } else if(doc.getBoxObjectFor) { 
      style.innerHTML += text;
    } else { 
      style.appendChild(doc.createTextNode(text)) 
    } 
  };

});

gulp-vue nodejs主要代码如下,通过文件名,来确定组件名字

var through = require('through2');
var gutil = require('gulp-util');

var regTpl = /<template>([\s\S]+?)<\/template>/;
var regStyle = /<style>([\s\S]+?)<\/style>/; 
var regJs = /<script>([\s\S]+?)<\/script>/; 
var reg = [/'/g, /\n/g, /([^\\]+)\.vue$/];

var vueWrite = function (file, str) {
  var match = file.path.match(reg[2]);
  var id = "vue-tpl-" + match[1];
  var appendJs = "";
  var res = "";
  str = str.replace(regTpl, function (t, h) {
    appendJs += "\tVue.appendHTML(\n'<template id=\"" + id + "\">" + h.replace(reg[0], "\\'").replace(reg[1], "\\\n") + "<\/template>');\n";
    return "";
  }).replace(regStyle, function (t, h) {
    appendJs += "\tVue.appendCSS(\n'" + h.replace(reg[0], "\\'").trim().replace(reg[1], "\\\n") + "');\n"
    return "";
  }).replace(regJs, function (t, h) {
    res = "define(function (require) {\n\trequire('VueCommon'); \n\tvar Vue = require('Vue');\n\tvar exports;\n" + appendJs + h + ";\n\texports.template = '#" + id + "';\n\texports = Vue.extend(exports);\n\tVue.component('" + match[1] + "', exports);\n\treturn exports;\n});"
    return ;
  })
  return res;
};

module.exports = function(opt){

 function run (file, encoding, callback) {
  if (file.isNull()) {
   return callback(null, file);
  }

  if (file.isStream()) {
   return callback(new gutil.PluginError('gulp-vue', 'doesn\'t support Streams'));
  }

  file.contents = new Buffer(vueWrite(file, file.contents.toString()));
  file.path = file.path + '.js';
  callback(null, file);
 }

 return through.obj(run);
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
侧栏跟随滚动的简单实现代码
Mar 18 Javascript
JS面向对象基础讲解(工厂模式、构造函数模式、原型模式、混合模式、动态原型模式)
Aug 16 Javascript
JavaScript中的索引数组、关联数组和静态数组、动态数组讲解
Nov 08 Javascript
JavaScript将字符串转换成字符编码列表的方法
Mar 19 Javascript
基于jquery实现可定制的web在线富文本编辑器附源码下载
Nov 17 Javascript
详解AngularJs路由之Ui-router-resolve(预加载)
Jun 13 Javascript
Vue实现一个返回顶部backToTop组件
Jul 25 Javascript
Vue.js 2.5新特性介绍(推荐)
Oct 24 Javascript
微信小程序选择图片和放大预览图片功能
Nov 02 Javascript
js实现input密码框显示/隐藏功能
Sep 10 Javascript
react 不用插件实现数字滚动的效果示例
Apr 14 Javascript
jQuery--遍历操作实例小结【后代、同胞及过滤】
May 22 jQuery
jQuery 控制文本框自动缩小字体填充
Jun 16 #jQuery
jQuery序列化后的表单值转换成Json
Jun 16 #jQuery
详解探索 vuex 2.0 以及使用 vuejs 2.0 + vuex 2.0 构建记事本应用
Jun 16 #Javascript
基于AngularJS实现的工资计算器实例
Jun 16 #Javascript
Angular+Node生成随机数的方法
Jun 16 #Javascript
JS利用正则表达式实现简单的密码强弱判断实例
Jun 16 #Javascript
vue高德地图之玩转周边
Jun 16 #Javascript
You might like
开发大型 PHP 项目的方法
2007/01/02 PHP
Laravel中使用阿里云OSS Composer包分享
2015/02/10 PHP
PHP cookie与session会话基本用法实例分析
2019/11/18 PHP
FF IE兼容性的修改小结
2009/09/02 Javascript
jsTree 基于JQuery的排序节点 Bug
2011/07/26 Javascript
基于mootools插件实现遮罩层新手引导
2012/05/24 Javascript
使用javascript实现监控视频播放并打印日志
2015/01/05 Javascript
jquery实现用户信息修改验证输入方法汇总
2015/07/18 Javascript
Bootstrap每天必学之基础排版
2015/11/20 Javascript
js过滤HTML标签完整实例
2015/11/26 Javascript
js判断复选框是否选中及选中个数的实现代码
2016/05/30 Javascript
jQuery实现的省市县三级联动菜单效果完整实例
2016/08/01 Javascript
基于JavaScript实现点击页面任何位置返回
2016/08/31 Javascript
vue-cli的eslint相关用法
2017/09/29 Javascript
使用cropper.js裁剪头像的实例代码
2017/09/29 Javascript
使用axios发送post请求,将JSON数据改为form类型的示例
2019/10/31 Javascript
javascript canvas实现简易时钟例子
2020/09/05 Javascript
python进阶教程之函数参数的多种传递方法
2014/08/30 Python
剖析Python的Twisted框架的核心特性
2016/05/25 Python
python实现字符串连接的三种方法及其效率、适用场景详解
2017/01/13 Python
wxPython之解决闪烁的问题
2018/01/15 Python
用Python写一个模拟qq聊天小程序的代码实例
2019/03/06 Python
python学习开发mock接口
2019/04/28 Python
python使用flask与js进行前后台交互的例子
2019/07/19 Python
Python Opencv 通过轨迹(跟踪)栏实现更改整张图像的背景颜色
2020/03/09 Python
python动态规划算法实例详解
2020/11/22 Python
研究生毕业鉴定
2014/01/29 职场文书
中专生毕业个人鉴定
2014/02/26 职场文书
行政人事专员岗位职责
2014/03/05 职场文书
售后服务承诺书
2014/03/26 职场文书
学雷锋宣传标语
2014/06/25 职场文书
优秀党员自我评价范文
2014/09/15 职场文书
公司优秀员工推荐信
2015/03/24 职场文书
党员身份证明材料
2015/06/19 职场文书
检讨书格式
2019/04/25 职场文书
Mysql中一千万条数据怎么快速查询
2021/12/06 MySQL