在普通页面中使用render函数渲染组件

render:function(createElements){//createElements是一个方法,调用它,能够把指定的组件模板,渲染成为HTML结构,这里面return的结果,会替换页面中el指定的那个容器

return createElements(login)

}

在webpack中配置.vue组件页面的解析

  1. 运行cnpm i vue -S将vue安装为运行依赖;

  2. 运行cnpm i vue-loader vue-template-compiler -D将解析转换vue的包安装为开发依赖;

  3. 运行cnpm i style-loader css-loader -D将解析转换CSS的包安装为开发依赖,因为.vue文件中会写CSS样式;

  4. webpack.config.js中,添加如下module和plugins规则:


module: {

  rules: [

    { test: /\.css$/, use: ['style-loader', 'css-loader'] },

    { test: /\.vue$/, use: 'vue-loader' }

  ]

}
const VueLoaderPlugin = require('vue-loader/lib/plugin')

module.exports = {
// ...
plugins: [
  new VueLoaderPlugin()
]
}
// 总结梳理: webpack 中如何使用 vue :
// 1. 安装vue的包: cnpm i vue -S
// 2. 由于 在 webpack 中,推荐使用 .vue 这个组件模板文件定义组件,所以,需要安装 能解析这种文件的 loader   cnpm i vue-loader vue-template-complier -D
// 3. 在 main.js 中,导入 vue 模块 import Vue from 'vue'
// 4. 定义一个 .vue 结尾的组件,其中,组件有三部分组成: template script style
// 5. 使用 import login from './login.vue' 导入这个组件
// 6. 创建 vm 的实例 var vm = new Vue({ el: '#app', render: c => c(login) })
// 7. 在页面中创建一个 id 为 app 的 div 元素,作为我们 vm 实例要控制的区域;
注意:在一个页面中只能有一个export default,可以有export,但是export只能使用{}接收,这个叫按需导出,export可以向外暴露多个成员,严格按照暴露的名称{}进行接收,但是可以用as起一个别名。
  1. 创建App.js组件页面:


  <template>

    <!-- 注意:在 .vue 的组件中,template 中必须有且只有唯一的根元素进行包裹,一般都用 div 当作唯一的根元素 -->

    <div>

      <h1>这是APP组件 - {{msg}}</h1>

      <h3>我是h3</h3>

    </div>

  </template>



  <script>

  // 注意:在 .vue 的组件中,通过 script 标签来定义组件的行为,需要使用 ES6 中提供的 export default 方式,导出一个vue实例对象

  export default {

    data() {

      return {

        msg: 'OK'

      }

    }

  }

  </script>



  <style scoped>

  h1 {

    color: red;

  }

  </style>
  1. 创建main.js入口文件:


  // 导入 Vue 组件

  import Vue from 'vue'



  // 导入 App组件

  import App from './components/App.vue'



  // 创建一个 Vue 实例,使用 render 函数,渲染指定的组件

  var vm = new Vue({

    el: '#app',

    render: c => c(App)

  });

在使用webpack构建的Vue项目中使用模板对象?

  1. webpack.config.js中添加resolve属性:

resolve: {
  alias: {
    'vue$': 'vue/dist/vue.js'
  }
}

ES6中语法使用总结

  1. 使用 export defaultexport 导出模块中的成员; 对应ES5中的 module.exportsexport

  2. 使用 import ** from **import '路径' 还有 import {a, b} from '模块标识' 导入其他模块

  3. 使用箭头函数:(a, b)=> { return a-b; }

在vue组件页面中,集成vue-router路由模块

vue-router官网

  1. 导入路由模块:


import VueRouter from 'vue-router'
  1. 安装路由模块:


Vue.use(VueRouter);
  1. 导入需要展示的组件:


import login from './components/account/login.vue'

import register from './components/account/register.vue'
  1. 创建路由对象:


var router = new VueRouter({

routes: [

  { path: '/', redirect: '/login' },

  { path: '/login', component: login },

  { path: '/register', component: register }

]

});
  1. 将路由对象,挂载到 Vue 实例上:


var vm = new Vue({

el: '#app',

// render: c => { return c(App) }

render(c) {

  return c(App);

},

router // 将路由对象,挂载到 Vue 实例上

});
  1. 改造App.vue组件,在 template 中,添加router-linkrouter-view


  <router-link to="/login">登录</router-link>

  <router-link to="/register">注册</router-link>



  <router-view></router-view>

组件中的css作用域问题

抽离路由为单独的模块

使用 饿了么的 MintUI 组件

Github 仓储地址

Mint-UI官方文档

  1. 导入所有MintUI组件:


import MintUI from 'mint-ui'
  1. 导入样式表:


import 'mint-ui/lib/style.css'
  1. 在 vue 中使用 MintUI:


Vue.use(MintUI)
  1. 使用的例子:


<mt-button type="primary" size="large">primary</mt-button>

使用 MUI 组件

官网首页

文档地址

  1. 导入 MUI 的样式表:


import '../lib/mui/css/mui.min.css'
  1. webpack.config.js中添加新的loader规则:


{ test: /\.(png|jpg|gif|ttf)$/, use: 'url-loader' }
  1. 根据官方提供的文档和example,尝试使用相关的组件

将项目源码托管到oschina中

  1. 点击头像 -> 修改资料 -> SSH公钥 如何生成SSH公钥

  2. 创建自己的空仓储,使用 git config --global user.name "用户名"git config --global user.email ***@**.com 来全局配置提交时用户的名称和邮箱

  3. 使用 git init 在本地初始化项目

  4. 使用 touch README.mdtouch .gitignore 来创建项目的说明文件和忽略文件;

  5. 使用 git add . 将所有文件托管到 git 中

  6. 使用 git commit -m "init project" 将项目进行本地提交

  7. 使用 git remote add origin 仓储地址将本地项目和远程仓储连接,并使用origin最为远程仓储的别名

  8. 使用 git push -u origin master 将本地代码push到仓储中

App.vue 组件的基本设置

  1. 头部的固定导航栏使用 Mint-UIHeader 组件;

  2. 底部的页签使用 muitabbar;

  3. 购物车的图标,使用 icons-extra 中的 mui-icon-extra mui-icon-extra-cart,同时,应该把其依赖的字体图标文件 mui-icons-extra.ttf,复制到 fonts 目录下!

  4. 将底部的页签,改造成 router-link 来实现单页面的切换;

  5. Tab Bar 路由激活时候设置高亮的两种方式:

  • 全局设置样式如下:


.router-link-active{

    color:#007aff !important;

  }
  • 或者在 new VueRouter 的时候,通过 linkActiveClass 来指定高亮的类:


// 创建路由对象

  var router = new VueRouter({

    routes: [

      { path: '/', redirect: '/home' }

    ],

    linkActiveClass: 'mui-active'

  });

实现 tabbar 页签不同组件页面的切换

  1. 将 tabbar 改造成 router-link 形式,并指定每个连接的 to 属性;

  2. 在入口文件中导入需要展示的组件,并创建路由对象:


  // 导入需要展示的组件

  import Home from './components/home/home.vue'

  import Member from './components/member/member.vue'

  import Shopcar from './components/shopcar/shopcar.vue'

  import Search from './components/search/search.vue'



  // 创建路由对象

  var router = new VueRouter({

    routes: [

      { path: '/', redirect: '/home' },

      { path: '/home', component: Home },

      { path: '/member', component: Member },

      { path: '/shopcar', component: Shopcar },

      { path: '/search', component: Search }

    ],

    linkActiveClass: 'mui-active'

  });

使用 mt-swipe 轮播图组件

  1. 假数据:


lunbo: [

      'http://www.itcast.cn/images/slidead/BEIJING/2017440109442800.jpg',

      'http://www.itcast.cn/images/slidead/BEIJING/2017511009514700.jpg',

      'http://www.itcast.cn/images/slidead/BEIJING/2017421414422600.jpg'

    ]
  1. 引入轮播图组件:


<!-- Mint-UI 轮播图组件 -->

  <div class="home-swipe">

    <mt-swipe :auto="4000">

      <mt-swipe-item v-for="(item, i) in lunbo" :key="i">

        <img :src="item" alt="">

      </mt-swipe-item>

    </mt-swipe>

  </div>

</div>

.vue组件中使用vue-resource获取数据

  1. 运行cnpm i vue-resource -S安装模块

  2. 导入 vue-resource 组件


import VueResource from 'vue-resource'
  1. 在vue中使用 vue-resource 组件


Vue.use(VueResource);

webpack(2)的更多相关文章

  1. 深入学习webpack(一)

    深入学习webpack(一) 模块化的相关库和工具已经很多了,包括require.js.sea.js和一些工程化工具webpack.gulp.grant.那么我们该如何选择呢? 其实,我们只需要掌握了 ...

  2. 玩转webpack(二):webpack的核心对象

    欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者介绍:陈柏信,腾讯前端开发,目前主要负责手Q游戏中心业务开发,以及项目相关的技术升级.架构优化等工作. 前言 webpack 是一个强大的模 ...

  3. vue(9)—— 组件化开发 - webpack(3)

    前面两个终于把webpack相关配置解析完了.现在终于进入vue的开发了 vue组件化开发预热 前期准备 创建如下项目: app.js: footer.js: main.js: webpack.con ...

  4. vue(8)—— 组件化开发 - webpack(2)

    webpack的常用loder和插件 loder和插件是什么,现在暂且不表,看到后面你就懂了 引入css问题 直接用link标签导入css 在前面的 vue(7)—— 组件化开发 — webpack( ...

  5. 深入学习webpack(二)

    深入学习webpack(二) 在深入学习webpack(一)中,我通过一个例子介绍了webpack的基本使用方法,下面将更为系统的学习webpack的基本概念,对于一门技术的掌握我认为系统化还是很重要 ...

  6. 走近webpack(5)--devtool及babel的使用

    这一章咱们来说一下如何使用babel以及如何用webpack调试代码.这是基础篇的最后一章,这些文章只是罗列的给大家讲解了在一些场景中webpack怎样使用,这章结束后会给大家讲解一下如何在我们实际的 ...

  7. 走近webpack(0)--正文之前的故事

    在前端工作的过程中,只要你接触过vue,angular,react,gulp就一定知道webpack或者听说过或者使用过webpack,但是或许你对webpack的使用方法并不是十分了解,只是会用写好 ...

  8. 走进webpack(1)--环境拆分及模块化

    初级的文章和demo已经基本完成了,代码也已经上传到了我的github上,如果你对webpack的使用并不是十分了解,那么建议你回头看下走近系列,里面包括了当前项目中使用频繁的插件,loader的讲解 ...

  9. 走进webpack(2)--第三方框架(类库)的引入及抽离

    在当代的前端开发中,很少会用原生JS来开发页面,最基本的都会使用jQuery来节省我们开发的时间和效率,而angular,vue,react的出现更是为前端开发者带来了福音.那么这篇文章就说说如何用w ...

  10. vue(7)—— 组件化开发 — webpack(1)

    引子 在研究完前面的vue开发后,其实已经可以自己开发点东西了,靠前面的指令集,组件,还有vue-router,还有异步请求这些知识点,是完全可以开发出来的,完全可以达到时下前后端分离的效果. 但是, ...

随机推荐

  1. bootstrap table 根据单元格中的数据改变单元格的样式

    在bootstrap-table.js里面列属性 formatter就是用来格式化单元格的,其默认值是undefined 类型是function,function(value,  row, index ...

  2. vue不支持IE8的原因

    当你把一个普通的 JavaScript 对象传给 Vue 实例的 data 选项,Vue 将遍历此对象所有的属性, 并使用 Object.defineProperty 把这些属性全部转为 getter ...

  3. 光流 LK 金字塔

    文章转载自:https://blog.csdn.net/sgfmby1994/article/details/68489944 光流是图像亮度的运动信息描述,这种运动模式指的是由一个观察者(比如摄像头 ...

  4. 洛谷P4009汽车加油行驶问题——网络流24题(最短路)

    题目:https://www.luogu.org/problemnew/show/P4009 网络流24题中不是网络流的最短路题: 把每个点拆成各个油量上的点,根据要求连边即可: 注意:点数最大为10 ...

  5. JSON标准格式

    标准JSON的合法符号:{(左大括号)  }(右大括号)  "(双引号)  :(冒号)  ,(逗号)  [(左中括号)  ](右中括号) JSON字符串:特殊字符可在字符前面加 \ 或使用 ...

  6. 华为G700电脑版Root软件-Eroot

    华为G700电脑版Root软件--eroot.zip(10.5M) 查阅全文 ›

  7. GetModuleFileNameW

    GetModuleFileNameW( HMODULE hModule, //模块句柄 或应用程序的实例句柄 若参数为NULL,则返回该应用程序全路径 __out_ecount(nSize) LPWS ...

  8. Console Event Handling

    http://www.codeproject.com/Articles/2357/Console-Event-Handling Console Event Handling Kumar Gaurav ...

  9. wmware7安装xp错误:虚拟CPU已经入关闭状态

    wm7安装xp错误提示: 虚拟CPU已经入关闭状态.这会造成物理计算机重新启动.这可能是虚拟机操作系统的错误或VMware Workstation软件中的一个配置不正确. 这种情是硬盘模式为AHCI模 ...

  10. UVA - 11987 Almost Union-Find 并查集的删除

    Almost Union-Find I hope you know the beautiful Union-Find structure. In this problem, you're to imp ...