搜索
首页web前端html教程webpack入坑之旅(五)加载vue单文件组件_html/css_WEB-ITnose

需要什么?

在经过前面的四个练习,相信已经对于 webapck有了一定的了解,现在我们就来一个综合案例,进一步甲申年对于 webpack的理解。

首先我们应该思考要解析 .vue类型的文件,需要什么样的东西?应该按照什么样的步骤来?我们应该怎么去搭建这个项目?

开始

第一步:初始化项目目录

我们需要创建如下目录及文件夹,最终目录结构如下:

- dist //文件生成目录    -- //自动生成- node_module //自动安装    -- ...- src //文件入口    -- components //组件存放        -- app.vue //主.vue    -- main.js //主.js- index.html //主.html- package.json //npm 配置- webpack.cofig.js // webpack配置

第二步:安装项目依赖

如果你上面没有创建 package.json文件的话,可以直接使用 npm init来初始化我们的 package.json文件的配置。

想要去编译其他的文件比如 react, coffce等等,就必须要加载很多对应的 loader。要想加载一个 .vue文件。当然也是同样的道理。

建议用 npm install xxx-loader --save-dev这样的命令一条一条的敲。在命令行中,会有提示,可以帮助理解 webpack的中的依赖管理关系。我的配置清单如下:

在实际项目中,json文件中不能出现注释,在这里为了方便大家了解里面设置项的含义,就直接使用注释的方式加载后面了。

{    "name": "05-five-vue", //项目名称    "version": "1.0.0", //版本    "description": "vue+webapck", //描述    "main": "index.js", //主文件    "scripts": {        "test": "echo \"Error: no test specified\" && exit 1",        "start": "webpack-dev-server --inline"    }, //scripts指定了运行脚本命令的npm命令行缩写,比如这是的start指定了运行npm run start时,所要执行的命令。    "dependencies": { //项目依赖        "vue": "^1.0.18"    },    "devDependencies": { //各种各样的loader,用来解析想相应的文件格式。要解析vue并且完成相应的功能,这些基本都是必须的。        "autoprefixer-loader": "^2.0.0",        "babel": "^6.3.13",        "babel-core": "^6.3.21",        "babel-loader": "^6.2.0",        "babel-plugin-transform-runtime": "^6.3.13",        "babel-preset-es2015": "^6.3.13",        "babel-runtime": "^5.8.34",        "css-loader": "^0.16.0",        "file-loader": "^0.8.5",        "html-loader": "^0.3.0",        "node-sass": "^3.4.2",        "sass-loader": "^3.2.0",        "style-loader": "^0.12.3",        "url-loader": "^0.5.6",        "vue-html-loader": "^1.2.0",        "vue-loader": "^7.2.0",        "webpack": "^1.12.0",        "webpack-dev-server": "^1.14.0"    },    "author": "guowenfh", //作者    "license": "MIT", //开源协议    "keywords": [ //关键字        "vue",        "webpack"    ]}

如果你想省事的话,直接复制上面的 devDependencies, dependencies字段,并且填写到你的 package.json文件中。然后运行 npm install就会自动安装所有的模块以及依赖。

第三步:配置webpack

文件已经设置好了,接下来就到了我们关键的一步,配置 webpack.config.js,清单如下:

var path = require('path');// NodeJS中的Path对象,用于处理目录的对象,提高开发效率。// 模块导入module.exports = {    // 入口文件地址,不需要写完,会自动查找    entry: './src/main',    // 输出    output: {        path: path.join(__dirname, './dist'),        // 文件地址,使用绝对路径形式        filename: '[name].js',        //[name]这里是webpack提供的根据路口文件自动生成的名字        publicPath: '/dist/'        // 公共文件生成的地址    },    // 服务器配置相关,自动刷新!    devServer: {        historyApiFallback: true,        hot: false,        inline: true,        grogress: true,    },    // 加载器    module: {        // 加载器        loaders: [        // 解析.vue文件            { test: /\.vue$/, loader: 'vue' },        // 转化ES6的语法            { test: /\.js$/, loader: 'babel', exclude: /node_modules/ },        // 编译css并自动添加css前缀            { test: /\.css$/, loader: 'style!css!autoprefixer'},        //.scss 文件想要编译,scss就需要这些东西!来编译处理        //install css-loader style-loader sass-loader node-sass --save-dev            { test: /\.scss$/, loader: 'style!css!sass?sourceMap'},        // 图片转化,小于8K自动转化为base64的编码            { test: /\.(png|jpg|gif)$/, loader: 'url-loader?limit=8192'},        //html模板编译?            { test: /\.(html|tpl)$/, loader: 'html-loader' },        ]    },    // .vue的配置。需要单独出来配置    vue: {        loaders: {            css: 'style!css!autoprefixer',            html:'html-loader'        }    },    // 转化成es5的语法    babel: {        presets: ['es2015'],        plugins: ['transform-runtime']    },    resolve: {        // require时省略的扩展名,如:require('module') 不需要module.js        extensions: ['', '.js', '.vue'],        // 别名,可以直接使用别名来代表设定的路径以及其他        alias: {            filter: path.join(__dirname, './src/filters'),            components: path.join(__dirname, './src/components')        }    },    // 开启source-map,webpack有多种source-map,在官网文档可以查到    devtool: 'eval-source-map'};

请详细查看这里面的设置,我这里都是很简单的配置,在你的项目中,还可以更进一步的对于入口文件和输出文件进行更加深入的定制。

并且在这里生成的css文件还会插到js中,有时我们需要更进一步的把它独立出来,然后在html中引入这时就会用到 webpack的插件,在这里先不说(因为我暂时没用到,没有试验过,好像也不麻烦,可以的话下篇再试试)

第四步:编写代码

接下来就是我们要展示的文件的编写了,我直接把代码贴上来了。

index.html:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>webpack vue</title>    <style> #app { margin: 20px auto; width: 800px; height: 600px; } </style></head><body>    <div id="app"></div>    <script src="dist/main.js"></script></body></html>

这里是main.js的内容:

//es6语法:import Vue from "../node_modules/vue/dist/vue.min.js";//其实不用写完,会自动查找。//外部引入别的库都可以用这样的方式,比如jquery等。。//引入我们编写的测试用vue文件。import app from './components/app';Vue.config.debug = true;//开启错误提示new Vue(app);

这里是app.vue:

<script> //es6 export default { el:"#app", //data:function(){},下面是es6写法 data () { return { name:"guowenfh", age:"2q1" } } }</script><template>    <div>        <h1 id="姓名-name">姓名:{{name}}</h1>        <h2 id="age">{{age}}</h2>    </div></template><style lang="sass"> /*测试一下对sass的编译*/ $qwe:#098; body{ background-color: $qwe; h1{ background-color: #eee; color: red; transform: translate(10%, 10%); } h1:hover{ height:100px; } h2{ background-color: #999; } }</style>

第五步:修改自动刷新设置

下面再单独的再谈一下关于自动刷新的实现,首先需要说明,在上一篇博客中的自动刷新实现,是有问题的。只能改变css样式,使颜色进行变化。对于html里面的内容改变时,浏览器并不会自动刷新。

注意点一:

首先我们看到 package.json中 scripts字段中的 "start": "webpack-dev-server --inline"。这里如果按照网上的方法在后面再添加上 --hot的话,只会对于 app.vue中的

注意点二:

因为我们没有加 --hot,所以在 webpack.cofig.js中需要对于 devServer进行一些配置,如下:(主要是是 hot设置为了false)。

devServer: {    historyApiFallback: true,    hot: false,    inline: true,    grogress: true,}

这样设置了之后按下保存相当于按下了F5浏览器整个刷新。而不是局部刷新。(如果你实现了局部刷新,并且没有其他问题,那请教教我^_^)

注意点三:

注意 package.json的loader安装中的 "vue-hot-reload-api": "^1.2.2"。它有可能是导致你不能自动刷新的凶手(我现在都没搞明白到底该安装,还是取消)

结束

步骤都走完了,因为在上面的 package.json中已经进行了 scripts项的配置。运行 npm start,打开 localhost:8080

可以看到设置的背景色已经出来了,去改变一下背景颜色?data?template?

看看浏览器会不会自动刷新?

如果你按照我的步骤,并且,npm包安装没有错误的话,应该就能成功了。

不行的话,请再仔细对照去看看有什么地方没有编写对吧!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
举一个带有属性的HTML标签的示例。举一个带有属性的HTML标签的示例。May 16, 2025 am 12:02 AM

HTML标签和属性的使用方法包括:1.基本用法:使用标签如和,通过属性如src和href添加必要信息。2.高级用法:使用data-*自定义属性实现复杂交互。3.避免常见错误:确保属性值用引号包围。4.性能优化:保持简洁,使用标准属性和CSS类名,确保图像有alt属性。掌握这些将提升网页开发技能。

HTML标签和HTML属性有什么区别?HTML标签和HTML属性有什么区别?May 14, 2025 am 12:01 AM

HTMLtagsdefinethestructureofawebpage,whileattributesaddfunctionalityanddetails.1)Tagslike,,andoutlinethecontent'splacement.2)Attributessuchassrc,class,andstyleenhancetagsbyspecifyingimagesources,styling,andmore,improvingfunctionalityandappearance.

HTML的未来:进化和趋势HTML的未来:进化和趋势May 13, 2025 am 12:01 AM

HTML的未来将朝着更加语义化、功能化和模块化的方向发展。1)语义化将使标签更明确地描述内容,提升SEO和无障碍访问。2)功能化将引入新元素和属性,满足用户需求。3)模块化将支持组件化开发,提高代码复用性。

为什么HTML属性对Web开发很重要?为什么HTML属性对Web开发很重要?May 12, 2025 am 12:01 AM

htmlattributesarecrucialinwebdevelopment forcontrollingBehavior,外观和功能

Alt属性的目的是什么?为什么重要?Alt属性的目的是什么?为什么重要?May 11, 2025 am 12:01 AM

alt属性是HTML中标签的重要部分,用于提供图片的替代文本。1.当图片无法加载时,alt属性中的文本会显示,提升用户体验。2.屏幕阅读器使用alt属性帮助视障用户理解图片内容。3.搜索引擎索引alt属性中的文本,提高网页的SEO排名。

HTML,CSS和JavaScript:示例和实际应用HTML,CSS和JavaScript:示例和实际应用May 09, 2025 am 12:01 AM

HTML、CSS和JavaScript在网页开发中的作用分别是:1.HTML用于构建网页结构;2.CSS用于美化网页外观;3.JavaScript用于实现动态交互。通过标签、样式和脚本,这三者共同构筑了现代网页的核心功能。

如何在标签上设置lang属性?为什么这很重要?如何在标签上设置lang属性?为什么这很重要?May 08, 2025 am 12:03 AM

设置标签的lang属性是优化网页可访问性和SEO的关键步骤。1)在标签中设置lang属性,如。2)在多语言内容中,为不同语言部分设置lang属性,如。3)使用符合ISO639-1标准的语言代码,如"en"、"fr"、"zh"等。正确设置lang属性可以提高网页的可访问性和搜索引擎排名。

HTML属性的目的是什么?HTML属性的目的是什么?May 07, 2025 am 12:01 AM

htmlattributeseresene forenhancingwebelements'functionalityandAppearance.TheyAdDinformationTodeFineBehavior,外观和互动,使网站互动,响应式,visalalyAppealing.AttributesLikutesLikeSlikEslikesrc,href,href,href,类,类型,类型,和dissabledtransfransformformformformformformformformformformformformformformforment

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。