上回模仿了一个nw,按照原理说,简单。

今天说Vue,脚手架是个好东西,做项目都给你配置好,nodejs很牛,不过对于我这种只想做一个界面的人来说,有点儿太大了,用不上。

如果说,不用脚手架 nodejs要面临哪些问题呢。

  1. 组件,组件文件vue,用的是es6语法,目前大多数浏览器不支持,其实就两个命令 import export,为了这点儿东西,哎,想想就烦。

  2. 不用组件呢?,vue的灵魂就两个,一个是mvvm模式的绑定,二个就是组件,确实想用。

没法想,自己加载吧,我们来聊一聊,手动加载vue文件组件吧。

先来分析一下

  1.vue是个什么东西:简单说,是一个对象,我们构建新的vue对象时候,要提供一个配置对象options,关键就在这个配置对象上。

  它包含了

    el:挂载点element

    data:数据

    methods:方法

     .....

  那么,

  2 . 组件是什么东西呢,嗯,简单的说也是一个对象,这个对象和vue配置类一样啊,多了一个template模板而已

  它也和vue配置对象一样,包含那几样东西。

  3. vue文件是什么东西呢,vue文件包含了什么呢,简单的说,包含了组件的模板和配置类options。

ok,现在清楚了,如果我们把vue文件解析一下,组合出一个配置类,也就是制造一个options,把模板放进去,他就是一个组件的配置类options

  再通过一些文档上指出的组件加载方式,完全可以,自行,动态的,加载vue文件,而不用脚手架,当然了,vue文件,本身也可以自己写,不用es6格式,有什么所谓呢。反正造出来就好了

重点,算是重点吧,具体要分哪几步

  1. 加载vue文件,没法,js是前端语言,要想问后端要文件,那就httprequest,httprequest是js原生的请求类,要是觉得麻烦,jquery里面也有ajex是这么写吧,我没用过,vue-resource也提供了一样的功能,此外还有好多,不列举了

  重点是,一定要用同步的请求去做我们要做的事,不管你用什么插件,还是用原生的,这里我说,原生的好搞一些。

  2. 分析vue,文件读上来了,分析也不叫分析吧,这太简单了,字符串分析,方法太多了,一个一字看,也行,分隔符分割也行,当然还有正则表达式,我们要做的提取个部分,<template>部分,<scripte>部分,<style>部分

  3. 组合,制造一个options对象,随你造咯,造好返回一个对象给Vue就好了。

全局对象就Vue.components()

局部对象就,组件options.components上面加一下。

我简单写了一个插件,用作配合非脚手架加载vue,不如看一下,我想也就都不用说了。

var vueloader = {
install : function(Vue,options){ Vue.ImportFrom = function(url){
url = window.location.href + url
var result RequestVue(url,function(r){
var context = r
if(context){
var script = getTagContext('script',context) var options = eval("("+script+")") options.template = getTagContext('template',context) result = options
} })
return result
} }
} function RequestVue(url,cb)
{
let request = new XMLHttpRequest()
request.user=''
request.open('GET',url,false)
request.send(null)
if (request.status === 200){
cb(request.responseText)
}
} function getTagContext(tag,str){
var reg = new RegExp("<"+tag+">([\\s\\S]*)<\/"+tag+">")
var matchs = reg.exec(str)
return matchs[1]
} Vue.use(vueloader)

插件要提供install方法,两个参数Vue,options

往Vue上挂一个方法importVue,然后最下面Vue.use 这个插件。

在你的 html中 <script src="vue-component-loader.js" type="text/javascript" charset="utf-8"></script>

这是我的插件文件名

之后,随便在js里面用了。

经过,我的一顿分析,eval()是个很牛逼的方法,它可以执行script,从而简化了很多麻烦事

我找个vue文件你看

<template>
<div>
<p>this is father:{{msg}}</p>
<p><button @click='say'>Say</button></p>
<cson :msgfrom = msgfromfather></cson>
</div>
}
</template> <script> {
name:'cfather',
data:function(){return{
msg:"",
msgfromfather:'msg from father'
}},
methods:{
say:function(){
this.msg = "hello you!"
this.msgfromfather = 'father:hello from father'
}
},
components:{'cson':Vue.ImportFrom('cson.vue')}
} </script> <style>
</style>

这是我写的vue文件,也是分来来template和script这些

那么,我不需要写 export default了,我直接一个对象就好了,因为我的解析工具里面,直接把这个对象字符串用eval()给实例化了

第二点, components:{'cson':Vue.ImportFrom('cson.vue')}

这里直接把插件里的加载方法写进去了,然后eval直接给执行了,多省事。

那么,该说的就说完了,回见了。



Vue 去脚手架的更多相关文章

  1. Vue 去脚手架插件,自动加载vue文件

    接上回 一些本质 本质上,去脚手架也好,读取vue文件也好,无非是维护options,每个Vue对象的初始化配置对象不触及Vue内部而言,在外部想怎么改都是可以的,只要保证options的正确,一切都 ...

  2. Vue 去脚手架插件,自动加载vue文件,style怎么办

    书接上上会,因为当时也没想好怎么办,所以装聋作哑的忽略了Vue文件中的Style,Vue的做法我看着晕乎乎的,细想的话,无非就是自动填写到dom中,所担心的无非是命名冲突. 在一个项目中(像我这种自娱 ...

  3. 简单vue项目脚手架(vue+webpack2.0+vuex+vue-router)

    github地址 使用技术栈 webpack(^2.6.1) webpack-dev-server(^2.4.5) vue(^2.3.3) vuex(^2.3.1) vue-router(^2.5.3 ...

  4. 分享一个vue项目“脚手架”项目的实现步骤

    搭建缘由 源于公司每次新启动一个由多人协同开发的项目都由负责人初始化项目之后,每个人再去从私服pull一下项目才开始开发.但是每次初始化工程都是一步步的造轮子,一个个依赖去安装,新建一个个不同功能的文 ...

  5. 13. Vue CLI脚手架

    一. Vue CLI 介绍 1. 什么是Vue CLI? Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统.Vue CLI 致力于将 Vue 生态中的工具基础标准化.它确保了各种构建工 ...

  6. 简单vue项目脚手架

    简单vue项目脚手架 github地址 使用技术栈 webpack(^2.6.1) webpack-dev-server(^2.4.5) vue(^2.3.3) vuex(^2.3.1) vue-ro ...

  7. vue.cli脚手架初次使用图文教程

    vue-cli作用 vue-cli作为vue的脚手架,可以帮助我们在实际开发中自动生成vue.js的模板工程. vue-cli使用 !!前提:需要vue和webpack 安装全局vue-cli npm ...

  8. 从0开始搭建vue+webpack脚手架(三)

    在从0开始搭建vue+webpack脚手架(二)中已经基本完成了开发环境的配置.当开发完成后,我们需要将完成的项目进行打包,接下来对打包做一些优化: 运行 $ npm run build 可生成dis ...

  9. 从0开始搭建vue+webpack脚手架(二)

    接着从0开始搭建vue+webpack脚手架(一) 三.配置webpack-dev-server 1. webpack-dev-server自带一个node的服务器, 项目在服务端运行的同时可以实现热 ...

随机推荐

  1. 深入浅出C/C++中的正则表达式库

    写在前面: 本文是面向有正则表达式基础的读者朋友的,如果你还不知道正则表达式是什么,请先到这里学习一下  :http://en.wikipedia.org/wiki/Regular_expressio ...

  2. 关于GitHubGit

    一.Github项目地址:https://github.com/gyguyt/Helloworld123 二.什么是Github? Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或 ...

  3. 如何从ERP将Material的Batch信息下载到CRM并存储在settype COMM_PR_BATCH里

    前提条件:必须先确保三个对象ATTRIBUTE, CLASS和OBJCL成功下载.可以到事物码R3AM1里查看,确保状态全部为Done. (1) 在事物码MM02里,切换到视图classificati ...

  4. 读REDIS数据结构

    一.DICT 主要有两个问题: 1.散列冲突,解决办法是拉链法 typedef struct dictEntry { void *key; union { void *val; uint64_t u6 ...

  5. Android进阶笔记11:ListView篇之ListView性能优化

    1. 首先思考一个问题ListView如何才能提高效率 ? 当convertView为空时候,用setTag()方法为每个View绑定一个存放控件的ViewHolder对象.当convertView不 ...

  6. swift的特性:扩展、协议、泛型

    swift的特性:扩展.协议.泛型 扩展与继承:对象的生长方式: 协议:支持 协议->类型.类型<-协议 的双向抽象: 泛型:

  7. 用户级线程demo

    http://blog.csdn.net/dabing69221/article/details/17426953 前言: 前几天复习了一下多线程,发现有许多网上讲的都很抽象,所以,自己把网上的一些案 ...

  8. linnx 修改ip地址

    vi /etc/sysconfig/network-scripts/ifcfg-eth0 [编辑网卡的配置文件] 输入上述命令后回车,打开配置文件,使用方向键移动光标到最后一行,按字母键“i”,进入编 ...

  9. ATK系列库说明

    初衷 重构和复用是软件的一个古老话题. 在日常的软件项目开发的过程序中,如何保证团队代码的强健,同时在不断变化的需过程中最大限度的保障代码的一致性,是项目开发中的难以控制的,我们可以借助各种源码管理和 ...

  10. CRS

    CRS是集群就绪服务(cluster ready service)的简称,主要负责集群中的资源管理以及OCR管理.为了与10gR2集群管理软件名称crs区分,这里用CRSD代替CRS.相关概念:--资 ...