当前位置: 首页 > news >正文

网站维护大概要多久/卖链接的网站

网站维护大概要多久,卖链接的网站,wordpress日系主题,多语言网站(如何实现网站的多语言版本 )以前都是支持 司徒正美 的,毕竟咱们也是跟着 司徒正美 一起走进了前端的世界。所以一般MVVM都是用avalon的,当然也是考虑到项目需要支持IE6,7,8的考虑。当然在用的时候也有一些小坑和bug,都处理了。今年正美正好升级avalon2.0,加入虚拟dom的时…

以前都是支持 司徒正美 的,毕竟咱们也是跟着 司徒正美 一起走进了前端的世界。所以一般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);
}

 

转载于:https://www.cnblogs.com/legu/p/5731766.html

http://www.lbrq.cn/news/970381.html

相关文章:

  • 建筑公司网站设计模板/网络营销的认识
  • 网站网络架构/全国新冠疫情最新消息
  • wordpress添加新php页面/seo教程 百度网盘
  • 外贸网站营销建站/b站新人视频怎么推广
  • 外链数是网站反向链接码/个人博客
  • 河南住房和城乡建设厅一体化平台网站/必应bing搜索引擎
  • 建设法律法规文本查询网站/郑州seo招聘
  • 经济与政府网站建设/深圳百度地图
  • 今日新闻头条内容/网站怎么做优化排名
  • 品辰设计的网站谁做的/教育机构加盟
  • 响应式网站 外贸/小吃培训机构排名前十
  • 分类网站有哪些/长沙好的seo外包公司
  • 网站建设实训日志/网络营销个人总结
  • 就业网站哪个靠谱/线上网络推广怎么做
  • 四川专门做招聘酒的网站/网络营销专业技能
  • 做网站产品图片素材/关键词优化最好的方法
  • 网站出现转站怎么办/seo 怎么做到百度首页
  • 阿里巴巴网站域名建设/nba西部排名
  • 网站产品要如何做详情/广州百度seo排名
  • 常德网站公司/百度一下你就知道官网
  • 一个人只做网站的流程/最近七天的新闻重点
  • 扬中市新闻网站/seo软件优化工具软件
  • 设计网站页面的作文/seo站内优化包括
  • 龙岩app定制/seo托管公司
  • 唐河做网站/seo视频教程汇总
  • 做的比较好的购物网站/百度开户需要什么资质
  • 学校门户网站建设的优势/网络推广引流是做什么工作
  • wordpress博客自媒体资讯主题/武汉seo和网络推广
  • 哪些网站做平面单页好看/搜索引擎公司排名
  • 中城投建设集团网站/手机网站seo免费软件
  • CentOS网络配置与LAMP环境搭建指南
  • 1.easypan-登录注册
  • java基础(day07)
  • Leaflet面试题及答案(81-100)
  • Linux操作系统之信号:信号的产生
  • 从零开始学习深度学习—水果分类之PyQt5App