Webpack + Vue.js 实战

简介: 在Vue.js中创建页面需要以下两步(1) 创建路由(2) 新建 vue 页面

1 创建路由


import hello from ‘@/component/Hello’

表示从当前目录下的 components 引入 Hello 文件,@表示当前目录,然后定义一个路由配置


041ebc5915044aeeb15d32d7b11f8457.png

// 引入 Vue
import Vue from 'vue'
// 引入 Vue 的路由
import Router from 'vue-router'
// 作用是引入 Hello 这个component
import hello from '../component/Hello'
//使用路由
Vue.use(Router)
export default new Router({
  routes: [
    {
      //路由路径,对应一个 url
      path: '/hello',
      //路由别名 ,vue.js内部使用的名称
      name: 'Hello',
      //组件,对应.vue页面的名字
      component: Hello
    }
  ]
})


当用户访问http://localhost:8080/#/hello时,就会渲染./components/Hello.vue 文件,name:'Hello'定义了该路由在 vue.js内部的名称


2 创建一个新的Component


之前在路由中引入了 component ,接下来,就是创建这个文件 📂


<template>
  <div>
    {{ message }}
  </div>
</template>
<script>
export default {
  data() {
    return {
      message: "你好,世界"
    };
  }
};
</script>
<style>
</style>

e632b61b833040e6ac28a06036d77e1c.gif

页面效果


原生 Vue.js的代码存在于 new Vue({……})中的代码,在Webpack 框架下,都应该放到`export default{……}`代码块中


3 Vue.js中的 ECMAScript


我们使用的不是原生的 “JavaScript”,而是一种新的语言,就是 ECMAScript,严格说,ECMAScript是 JavaScript 的规范


let,var,常量与局部变量

声明本地变量,使用 let 和 var ,两者的区别如下

✨var:可能引起变量提升,或块级作用域的问题

✨let:就是为了解决以上问题存在的

在webpack下的vue.js中使用任何变量,都要使用var或let来声明


常量:


var a = 1;
let b = 10;
const NAME = '小刘';
console.log(a);
console.log(b);
console.log(NAME);


导入代码:import


import 用于导入外部代码,例如:

因为Vue和Router是在package.json中定义的,因此可以直接 import … from 包名引入,否则要加上路径


// 引入 Vue
import Vue from 'vue'
// 引入 Vue 的路由
import Router from 'vue-router'


在from后面添加@符号,表示的是在本地文件系统中引入文件,@代表源代码目录,一般是 src,@出现之前,我们在编码时也是这样写:


import Hello from '../components/Hello'


因为大量使用相对路径,这样会导致代码混乱,所以推荐使用@写路径


方便其他代码使用自己:export default { … }


在每个 vue 文件的<script>中,都会存在 export default { … } 代码,作用是方便其他代码对这个代码进行引用,对于 Vue.js 程序员来说,记住这个写法就可以了


在es6之前,js 没有统一的模块定义


ES中的简写


有时候会发现这样的代码


<script>
export default {
  data() {
    return {
      message: "你好,世界"
    };
  },
  methods:{
    print(){
      var a = 1;
      let b = 10;
      const NAME = '小刘';
      console.log(a);
      console.log(b);
      console.log(NAME);
    }
  }
};
</script>


实际中,上面代码是一种简写形式,等同于下面的代码


<script>
export default {
  data: function() {
    return {
      message: "你好,世界"
    };
  },
  methods: {
    print: function() {
      var a = 1;
      let b = 10;
      const NAME = "小刘";
      console.log(a);
      console.log(b);
      console.log(NAME);
    }
  }
};
</script>


箭头函数=>


main.js加上Vue.prototype.$axios = axios axios.get改为this.$axios.get调用


import axios from 'axios'
//其他vue组件中就可以this.$axios调用使用
Vue.prototype.$axios = axios


methods: {
  getData(){
    this.$axios.get('https://api.uomg.com/api/rand.music')
    .then(resp=>{
      console.log(resp);
    })
  },
  getData1(){
    this.$axios.get('https://api.uomg.com/api/rand.music')
    .then(function(resp){
      console.log(resp);
    })
  }
}


ES 新增的箭头表示函数,默认指向定义它时,所处上下文的对象的this指向。即ES6箭头函数里this的指向就是上下文里对象this指向,偶尔没有上下文对象,this就指向window


hash 中同名的 key,value 可以简写


<script>
export default {
  data: function() {
    let title = "你好,世界"
    return {
      title:title
    };
  }
};
</script>

ebe1135eb01742a2b187008e1492475e (1).png


可以简写为:


<script>
export default {
  data: function() {
    let title = "你好,世界"
    return {
      title
    };
  }
};
</script>


一样的


ebe1135eb01742a2b187008e1492475e (1).png


分号可以省略


var a = 1
var b = 2


等同于


var a = 1;
var b = 2;


相关文章
|
1月前
|
JavaScript
Nest.js 实战 (十一):配置热重载 HMR 给服务提提速
这篇文章介绍了Nest.js服务在应用程序引导过程中,TypeScript编译对效率的影响,以及如何通过使用webpackHMR来降低应用实例化的时间。文章包含具体教程,指导读者如何在项目中安装依赖包,并在根目录下新增webpack配置文件webpack-hmr.config.js来调整HMR相关的配置。最后,文章总结了如何通过自定义webpack配置来更好地控制HMR行为。
|
1月前
Nest.js 实战 (十三):实现 SSE 服务端主动向客户端推送消息
这篇文章介绍了在Nest.js应用中使用Server-Sent Events (SSE)的技术。文章首先讨论了在特定业务场景下,为何选择SSE而不是WebSocket作为实时通信系统的实现方式。接着解释了SSE的概念,并展示了如何在Nest.js中实现SSE。文章包含客户端实现的代码示例,并以一个效果演示结束,总结SSE在Nest.js中的应用。
Nest.js 实战 (十三):实现 SSE 服务端主动向客户端推送消息
|
18天前
|
JavaScript 前端开发 安全
js逆向实战之烯牛数据请求参数加密和返回数据解密
【9月更文挑战第20天】在JavaScript逆向工程中,处理烯牛数据的请求参数加密和返回数据解密颇具挑战。本文详细分析了这一过程,包括网络请求监测、代码分析、加密算法推测及解密逻辑研究,并提供了实战步骤,如确定加密入口点、逆向分析算法及模拟加密解密过程。此外,还强调了法律合规性和安全性的重要性,帮助读者合法且安全地进行逆向工程。
66 11
|
13天前
|
缓存 资源调度 JavaScript
万字总结webpack实战案例配置
该文章总结了Webpack在实际项目中的配置案例,包括如何配置多页面应用、使用高级插件、优化构建速度及减少输出文件大小等方面的实战经验。
|
13天前
|
设计模式 前端开发 JavaScript
webpack实战之手写一个loader和plugin
该文章详细讲解了如何从零开始编写一个自定义的Webpack Loader和Plugin,包括它们的工作原理、开发步骤以及如何将自定义的Loader和Plugin集成到Webpack配置中。
webpack实战之手写一个loader和plugin
|
2月前
|
SQL 运维 监控
Nest.js 实战 (十):使用 winston 打印和收集日志记录
这篇文章介绍了在Nest服务中如何使用Winston记录日志。文章首先强调了日志记录在后台服务中的重要性,接着提到Nest默认的内部日志记录器,并指出可以通过@nestjs/common包中的Logger类来全面控制日志系统的行为。文章还提到,为了在生产环境中实现更高级的日志功能,可以使用如Winston之类的Node.js日志包。接下来,文章介绍了如何在Nest服务中使用Winston记录日志,包括安装相关依赖、创建winston配置文件以及实现简单的日志记录示例。最后,文章指出更高级的自定义日志功能需要读者自己去探索。
Nest.js 实战 (十):使用 winston 打印和收集日志记录
|
1月前
Nest.js 实战 (十二):优雅地使用事件发布/订阅模块 Event Emitter
这篇文章介绍了在Nest.js构建应用时,如何通过事件/发布-订阅模式使应用程序更健壮、灵活、易于扩展,并简化服务间通信。文章主要围绕@nestjs/event-emitter模块展开,这是一个基于eventemitter2库的社区模块,提供了事件发布/订阅功能,使得实现事件驱动架构变得简单。文章还介绍了如何使用该模块,包括安装依赖、初始化模块、注册EventEmitterModule、使用装饰器简化监听等。最后总结,集成@nestjs/event-emitter模块可以提升应用程序的事件驱动能力,构建出更为松耦合、易扩展且高度灵活的系统架构,是构建现代、响应迅速且具有高度解耦特性的Nest.
|
13天前
|
JavaScript 前端开发 UED
组件库实战 | 用vue3+ts实现全局Header和列表数据渲染ColumnList
该文章详细介绍了如何使用Vue3结合TypeScript来开发全局Header组件和列表数据渲染组件ColumnList,并提供了从设计到实现的完整步骤指导。
|
2月前
|
JavaScript 数据安全/隐私保护 Python
网易云音乐搜索接口JS逆向: Params、encSecKey加密和AES实战
网易云音乐搜索接口JS逆向: Params、encSecKey加密和AES实战
57 4
|
2月前
|
前端开发 JavaScript 开发者
前端JS按钮点击事件、跳出弹窗、遮罩的实战示例
本文提供了一个前端JS按钮点击事件、弹出式窗口和遮罩层的实战示例,包括HTML、CSS和JavaScript的具体实现代码,以及功能解析,演示了如何实现按钮点击后触发弹窗显示和遮罩层,并在2秒后自动关闭或点击遮罩层关闭弹窗的效果。
前端JS按钮点击事件、跳出弹窗、遮罩的实战示例