Vue基础知识总结 9:vue webpack打包原理_vue打包,计算机vb编程

2、less示例

将 css-loader、style-loader 和 less-loader 链式调用,可以把所有样式立即应用于 DOM。

module.exports = {

module: {
rules: [{
test: /.less$/,
use: [{
loader: “style-loader” // creates style nodes from JS strings
}, {
loader: “css-loader” // translates CSS into CommonJS
}, {
loader: “less-loader” // compiles Less to CSS
}]
}]
}
};

3、安装url-loader

npm install --save-dev url-loader

4、url-loader用法

url-loader 功能类似于 file-loader,但是在文件大小(单位 byte)低于指定的限制时,可以返回一个 DataURL。

import img from ‘./image.png’

webpack.config.js

module.exports = {
module: {
rules: [
{
test: /.(png|jpg|gif)$/,
use: [
{
loader: ‘url-loader’,
options: {
limit: 8192
}
}
]
}
]
}
}

当图片大小大于limit中限制时,需要使用file-loader进行图片加载,再转为base64字符串。

5、file-loader

1、安装file-loader

npm install --save-dev file-loader

七、加载图片代码实例

1、项目目录

2、index.html
Title
3、main.js

// 1.使用commonjs的模块化规范
const {add, mul} = require(‘./js/mathUtils.js’)

console.log(add(20, 30));
console.log(mul(20, 30));

// 2.使用ES6的模块化的规范
import {name, age, height} from “./js/info”;

console.log(name);
console.log(age);
console.log(height);

// 3.依赖css文件
require(‘./css/normal.css’)

// 4.依赖less文件
require(‘./css/special.less’)
document.writeln(‘

你好啊,哪吒!

’)

4、info.js

export const name = ‘why’;
export const age = 18;
export const height = 1.88;

5、mathUtils.js

export const name = ‘why’;
export const age = 18;
export const height = 1.88;

6、normal.css

body {
/background-color: red;/
background: url(“…/img/timg.jpg”);
}

7、special.less

@fontSize: 50px;
@fontColor: orange;

body {
font-size: @fontSize;
color: @fontColor;
}

八、ES6语法处理

webpack打包的js文件,并没有将ES6语法转译成ES5的语法,因此可能对某些浏览器不兼容,此时需要使用babel。

1、安装babel-loader

npm install --save-dev babel-loader@7 babel-core babel-preset-es2015

2、在 webpack 配置对象中,需要添加 babel-loader 到 module 的 loaders 列表中,

像下面这样:

module: {
rules: [
{
test: /.js$/,
exclude: /(node_modules|bower_components)/,
use: {
loader: ‘babel-loader’,
options: {
presets: [‘es2015’]
}
}
}
]
}

bundle.js从ES6语法编译为ES5语法了。

九、webpack使用vue的配置过程

1、安装vue的三种方式
  1. 直接下载应用
  2. CDN引入
  3. npm安装
2、npm安装vue

因为不是运行时依赖,以后部署的时候也要使用vue,所以不需要-vue

npm install vue --save

runtime-only -> 代码中,不可以有任何的template

runtime-compiler -> 代码中可以有template,因为有compiler可以用于编译template

使用如下配置解决找不到template的报错问题:

resolve: {
// alias: 别名
extensions: [‘.js’, ‘.css’, ‘.vue’],
alias: {
‘vue$’: ‘vue/dist/vue.esm.js’
}
}

十、el和template区别

1、正常运行之后,我们要考虑一个问题

如果我们将data中的数据显示在界面中,就必须修改index.html;

如果我们后面自定义了组件,也必须修改index.html来使用组件;

但是html模板在之后的开发中,并不希望手动的频繁的修改index.html;

2、解决方法 --> 定义template属性

在前面的Vue实例中,我们定义了el属性,用于和index.html中的#app进行绑定,让Vue实例之后可以管理它其中的内容;

这里我们可以将div元素中的{{message}}内容删掉,只保留一个基本的id为div的元素;

但是如果我们依然希望在其中显示{{message}}的内容,我们可以定义一个template属性;

如果el和template同时存在时,template会替换掉el的内容:

new Vue({
el:‘#app’,
template:`

{{message}}

简化:

const App = {
template:`

{{message}}

new Vue({
el:‘#app’,
template:<App/>,
components:{
App
}
})

再次简化:

app.js

export default {
template: `

{{message}}

}
}
}

main.js

// 5.使用Vue进行开发
import Vue from ‘vue’
import App from ‘./vue/app’

new Vue({
el: ‘#app’,
template: ‘’,
components: {
App
}
})

终极优化

App.vue

{{message}}

main.js

// 5.使用Vue进行开发
import Vue from ‘vue’
import App from ‘./vue/App.vue’

new Vue({
el: ‘#app’,
template: ‘’,
components: {
App
}
})

但是,此时程序无法加载vue文件,需要npm安装loader

npm install vue-loader vue-template-compiler --save-dev

webpack.config.js中配置:


{
test: /.vue$/,
use: [‘vue-loader’]
}

十一、认识plugin

1、plugin是什么?

plugin是插件的意思,通常适用于对某个现有的框架的扩展。

webpack中的插件,就是对webpack现有功能的各种扩展,比如打包优化,文件压缩等。

2、loader和plugin的区别?

loader主要用于转换某些类型的模板,它是一个转换器。

plugin是插件,它是对webpack本身的扩展,是一个扩展器。

3、plugin的使用过程
  1. 通过npm安装需要使用的plugins
  2. 在webpack.config.js中的plugins中配置插件
4、代码实例

plugins: [
new webpack.BannerPlugin(‘最终版权归aaa所有’),
],

5、htmlWebpackPlugin

(1)、作用

  1. 自动生成一个index.html文件
  2. 将打包的js文件,自动通过script标签插入到body中

(2)安装htmlWebpackPlugin

npm install htnl-webpack-plugin --save-dev

(3)使用插件

修改webpack.config.js文件中plugins部分的内容

plugins: [
new webpack.BannerPlugin(‘最终版权归aaa所有’),
new HtmlWebpackPlugin({
template: ‘index.html’
})
],

6、第三方插件uglifyjs-webpack-plugin

指定版本1.1.1,和CLI2保持一致。

(1)安装

npm install uglifyjs-webpack-plugin@1.1.1 --save-dev

(2)修改配置文件

plugins: [
new webpack.BannerPlugin(‘最终版权归aaa所有’),
new HtmlWebpackPlugin({
template: ‘index.html’
}),
new UglifyjsWebpackPlugin()
],

7、webpack-dev-server搭建本地服务器

(1)webpack-dev-server简介

webpack提供了一个可选的本地开发服务器,这个本地服务器基于node.js搭建,内部使用express框架,可以实现我们想要的让浏览器自动刷新显示我们修改后的结果。

(2)安装

npm install --save-dev webpack-dev-server@2.9.1

(3)属性介绍

devserver作为webpack的一个选项,选项本身可以设置如下属性:

  1. contentBase:为哪一个文件夹提供本地服务,默认是根文件夹,我们这里要填写./dist
  2. port:端口号
  3. inline:页面实时刷新
  4. historyApiFallback:在SPA页面中,依赖HTML5的history模式

(4)配置实例

devServer: {
contentBase: ‘./dist’,
inline: true
}

8、webpack配置文件的分离

(1)安装插件

npm install webpack-merge --save-dev

(2)分离代码实例

webpack-config.js

const path = require(‘path’)

module.exports = {
entry: ‘./src/main.js’,
output: {
path: path.resolve(__dirname, ‘dist’),
filename: ‘bundle.js’,
publicPath: ‘dist/’
},
module: {
rules: [
{
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 119: …'css-loader' ] }̲, { test: /\.le…/,
use: [{
loader: “style-loader”, // creates style nodes from JS strings
}, {
loader: “css-loader” // translates CSS into CommonJS
}, {
loader: “less-loader”, // compiles Less to CSS
}]
},
{
test: /.(png|jpg|gif|jpeg)KaTeX parse error: Expected 'EOF', got '}' at position 186: ….[ext]' }, } ] }̲, { test: /\.js/,
// exclude: 排除
// include: 包含
exclude: /(node_modules|bower_components)/,
use: {
loader: ‘babel-loader’,
options: {
presets: [‘es2015’]
}
}
},
{
test: /.vueKaTeX parse error: Expected 'EOF', got '}' at position 24: …['vue-loader'] }̲ ] }, resolve: …’: ‘vue/dist/vue.esm.js’
}
}
}

build/base.config.js

const path = require(‘path’)
const webpack = require(‘webpack’)
const HtmlWebpackPlugin = require(‘html-webpack-plugin’)
const UglifyjsWebpackPlugin = require(‘uglifyjs-webpack-plugin’)

module.exports = {
entry: ‘./src/main.js’,
output: {
path: path.resolve(__dirname, ‘…/dist’),
filename: ‘bundle.js’,
// publicPath: ‘dist/’
},
module: {
rules: [
{
test: /.cssKaTeX parse error: Expected 'EOF', got '}' at position 119: …'css-loader' ] }̲, { test: /\.le…/,
use: [{
loader: “style-loader”, // creates style nodes from JS strings
}, {
loader: “css-loader” // translates CSS into CommonJS
}, {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数同学面临毕业设计项目选题时,很多人都会感到无从下手,尤其是对于计算机专业的学生来说,选择一个合适的题目尤为重要。因为毕业设计不仅是我们在大学四年学习的一个总结,更是展示自己能力的重要机会。

因此收集整理了一份《2024年计算机毕业设计项目大全》,初衷也很简单,就是希望能够帮助提高效率,同时减轻大家的负担。
img
img
img

既有Java、Web、PHP、也有C、小程序、Python等项目供你选择,真正体系化!

由于项目比较多,这里只是将部分目录截图出来,每个节点里面都包含素材文档、项目源码、讲解视频

如果你觉得这些内容对你有帮助,可以添加VX:vip1024c (备注项目大全获取)
img

从右向左
use: [ ‘style-loader’, ‘css-loader’ ]
},
{
test: /.less$/,
use: [{
loader: “style-loader”, // creates style nodes from JS strings
}, {
loader: “css-loader” // translates CSS into CommonJS
}, {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数同学面临毕业设计项目选题时,很多人都会感到无从下手,尤其是对于计算机专业的学生来说,选择一个合适的题目尤为重要。因为毕业设计不仅是我们在大学四年学习的一个总结,更是展示自己能力的重要机会。

因此收集整理了一份《2024年计算机毕业设计项目大全》,初衷也很简单,就是希望能够帮助提高效率,同时减轻大家的负担。
[外链图片转存中…(img-efGcoWJ6-1712538629045)]
[外链图片转存中…(img-uWOKdqE4-1712538629045)]
[外链图片转存中…(img-1kkuULvb-1712538629046)]

既有Java、Web、PHP、也有C、小程序、Python等项目供你选择,真正体系化!

由于项目比较多,这里只是将部分目录截图出来,每个节点里面都包含素材文档、项目源码、讲解视频

如果你觉得这些内容对你有帮助,可以添加VX:vip1024c (备注项目大全获取)
[外链图片转存中…(img-Bsmv4aL1-1712538629046)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值