webpack + Vue 组件/路由

5 篇文章 0 订阅

安装成生产依赖

npm install vue -S

index.html中导入app模块

main.js 开始写vue

import Vue from "vue"

var vm = new Vue({
    el:"#app",
    data:{
        msg:"vue+webpack"
    },
    methods: {
        
    },
})

启动服务 npm run start

报错:运行时的版本,不能进行编译

 因为上面那种vue写法需要编译器,而.。

解决办法:一)导入完整版的vue

二)起别名

 

********************************

组件的使用

//1.导入vue的运行版本
//import Vue from 'vue'
//2.编写单页面的vue组件 mycomp.vue
//3.import mycomp from "./mycomp.vue"
//4.npm install vue-loader vue-template-compiler -D
//5.使用render函数组件渲染

1/导入vue运行版本  原先定义组件的方式

2/启动 npm run star,差值表达式一闪而过,报错。需要自己写render函数,就不需要编译。

可简写为

还是会报错。因为都需要完整版的vue,但咱不想用完整版的vue。

2/所以需要把东西拿出来写一个vue文件(单文件组件)

 

3/导入mycomp.vue  用render渲染    render: c => c(App)

4/安装vue loader

npm install vue-loader vue-template-compiler -D

5/导入

插件配置

***************************************

数据导出

script文件夹下新建文件test.js,存放数据

//向外暴露成员
export default {
    name:'tom',
    age:'30'
}

export var person2 ={
    name:'JACK',
    age:'20'
}
export var person3 ={
    name:'xiaosan',
    age:'20'
}

main.js中向外暴露数据

import eee,{person2,person3 as san} from "./js/test"
console.log(eee.name,person2.name,san.name);

注意

  • export default向外暴露的数据,可以用任意的变量来接受 
  • 在一个模块中 export default 只允许向外暴露1次
  • 在一个模块中 export default和export可以同时向外暴露数据
  • 用 export 向外暴露的成员 只能使用{}的形式来接收,称为 按需导出
  • 用 export 可以向外暴露多个成员,可以按需要 import
  • 用 export 导出的成员,在import的时候 名称必须和导出的名称一致
  • 如果想换个名称来导入,可以使用as定义别名

**************************

路由的使用

安装

npm install vue-router -S

在main.js中引入并设置路由规则


//通过这种方式导入的是 运行时版本
import Vue from 'vue'

import VueRouter from "vue-router"
Vue.use(VueRouter)

//导入组件
import App from "./App.vue"
import MyComp1 from "./components/MyComp1.vue"
import MyComp2 from "./components/MyComp2.vue" 

//设置路由规则
var router=new VueRouter({
    routes:[
        {path:"/mycomp1",component:MyComp1},
        {path:"/mycomp2",component:MyComp2},
    ]
})

//需要编译器
var vm = new Vue({
    el: "#app",
    data: {
        msg: "vue+webpack子组件的使用"
    },
    methods: {
    },
    render: c => c(App),
    router
})

创建根组件app.vue

<template>
  <div>
    <h1>{{msg}}</h1>

    <router-link to="/mycomp1">MyComp1</router-link>
    <router-link to="/mycomp2">MyComp1</router-link>
    <router-view></router-view>
  </div>
</template>

<script>
export default {
  data() {
    return {
      msg: "App组件"
    };
  },
  methods: {
    show() {
      console.log("show is called");
    }
  }
};
</script>

<style>
</style>

创建子组件 MyComp1.vue   MyComp2.vue

<template>
  <div>
      <h1>子组件 MyComp1 </h1>
  </div>
</template>

<script>
export default {

}
</script>

<style>

</style>

****************************************

路由嵌套

把路由配置单独拿出来,最后导出router,并在main.js中引入  import router from "./script/router.js"

import VueRouter from "vue-router"
import MyComp from "../components/MyComp.vue"
import MyComp1 from "../components/MyComp1.vue"
import MyComp2 from "../components/MyComp2.vue"

//设置路由规则
var router = new VueRouter({
    routes: [
           //设置默认访问地址
        { path: "/", redirect: "/mycomp" },
        {    
            path: "/mycomp",
            component: MyComp,
            //子路由配置
            children: [
                { path: "", component: MyComp1 },
                { path: "mycomp1", component: MyComp1 },
                { path: "mycomp2", component: MyComp2 }
            ]
        }
    ]
})

export default router

*****************************
scoped  css

<style lang="scss" scoped>
body {
  div {
    font-style: italic;
  }
}
</style>

scoped只对自身和其子组件有作用

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值