Day 75 vue 03 Vue自动化工具
使用vue自动化工具可以快速搭建单页应用项目目录。
该工具为现代化的前端开发工作流提供了开箱即用的构建配置。只需几分钟即可创建并启动一个带热重载、保存时静态检查以及可用于生产环境的构建配置的项目:
// 生成一个基于 webpack 模板的新项目
vue init webpack 项目名
例如:
vue init webpack myproject
// 启动开发服务器 ctrl+c 停止服务
cd myproject
npm run dev # 运行这个命令就可以启动node提供的测试http服务器
├── build/ ├── config/ ├── index.html ├── node_modules/ # 项目运行的依赖库存储目录[非常大] ├── package.json # 项目运行需要的依赖库记录配置 ├── src/ │ ├── App.vue # 父级组件 │ ├── assets/ # 静态资源目录,图片存放在这里 │ ├── components/ # 单文件组件保存目录 │ └── main.js └── static/ # 静态资源目录,所有的css,js等文件放在这个目录
static :静态资源目录,所有的css,js文件放在这个文件夹
dist :项目打包发布文件夹,最后要上线单文件项目文件都在这个文件夹中[后面打包项目,让项目中的vue组件经过编译变成js 代码以后,dist就出现了]
node_modules:目录是node的包目录,
config:是配置目录,
build:是项目打包时依赖的目录
src/router: 路由,后面需要我们在使用Router路由的时候,自己声明.

整个项目是一个访问入口文件index.html,index.html中会引入src文件夹中的main.js,main.js中会导入顶级单文件组件App.vue,App.vue中会通过组件嵌套或者路由来引用components文件夹中的其他单文件组件。
组件有两种:普通组件、单文件组件
普通组件的缺点:
-
html代码是作为js的字符串进行编写,所以组装和开发的时候不易理解,而且没有高亮效果。
-
普通组件用在小项目中非常合适,但是复杂的大项目中,如果把更多的组件放在html文件中,那么维护成本就会变得非常昂贵。
-
普通组件只是整合了js和html,但是css代码被剥离出去了。使用的时候的时候不好处理。
vue文件:
将一个组件相关的html结构,css样式,以及交互的JavaScript代码从html文件中剥离出来,合成一个文件,这种文件就是单文件组件,相当于一个组件具有了结构、表现和行为的完整功能,方便组件之间随意组合以及组件的重用,这种文件的扩展名为“.vue”,比如:"Home.vue"。
在组件中编辑三个标签,编写视图template、vm对象script标签和css样式代码style。
<template>
<div id="Home">
<Header/>
<div class="main">
页面主题内容
</div>
<div class="footer">
页面脚步内容
</div>
</div>
</template>
<script>
import Header from "./common/Header"
export default {
name:"Home", // 组件名称,用于以后路由跳转
data(){ // 当前组件中需要使用的数据
return {
num:0
}
},
components:{ // 要使用的子组件
Header,
}
}
</script>
// scoped 表示当前style的样式只作用于当前组件的template代码中,其他地方不会被影响 <style scoped> .header{ height: 100px; line-height: 100px; background-color: #eee; text-align: center; } </style>
在common目录下创建Header.vue
<template> <div id="Header" class="header"> 页面头部 </div> </template> <script> export default { name:"Header", // 组件名称,用于以后路由跳转 data(){ // 当前组件中需要使用的数据 return { } } } </script> // scoped 表示当前style的样式只作用于当前组件的template代码中,其他地方不会被影响 <style scoped> .header{ height: 100px; line-height: 100px; background-color: #eee; text-align: center; } </style>
有时候开发vue项目时,页面也可以算是一个大组件,同时页面也可以分成多个子组件.
因为,产生了父组件调用子组件的情况.
例如,我们可以声明一个组件,作为父组件
在components/创建一个保存子组件的目录commonn,

创建一个父组件Hello_header:
<template> <div id="Hello_header"> <h1>我是头部</h1> <p>{{ msg }}</p> <button @click="num++">+</button> <input type="text" v-model="num"> <button @click="num--">-</button> <Hello_son/> // 调用子组件 </div> </template> <script> import Hello_son from "./common/Hello_son" // 在script里面导入子组件,并且起别名 export default { data(){ return { msg:"这是具体内容", num:0 } }, components:{ Hello_son // 子组件 } } </script> <style> </style>
创建Hello_header的子组件:
<template> <div id="Hello_son"> <p class="son">{{msg}}</p> </div> </template> <script> export default { data(){ return { msg:'只是头部的儿子噢' } } } </script> <style> .son{ color:red; } </style>
<Menu :mynum="num" title="home里面写的数据"/>
# 上面表示在父组件调用Menu子组件的时候传递了2个数据:
如果要传递变量[变量可以各种类型的数据],属性名左边必须加上冒号:,同时,属性名是自定义的,会在子组件中使用。
如果要传递普通字符串数据,则不需要加上冒号:
第二步:在子组件中接受上面父组件传递的数据,需要在vm组件对象中,使用props属性类接受。
<script>
export default {
name:"Menu",
props:["mynum","title"],
data: function(){
return {
msg:"这是Menu组件里面的菜单",
}
}
}
</script>
// 上面 props属性中表示接受了两个数据。
第三步:在子组件中的template中使用父组件传递过来的数据.
<template>
<div id="menu">
<span>{{msg}},{{title}}</span>
<div>hello,{{mynum}}</div>
</div>
</template>

用父组件传递数据给子组件时, 注意一下几点:
-
传递数据是变量,则需要在属性左边添加冒号
传递数据是变量,这种数据称之为"动态数据传递"
传递数据不是变量,而是数值或者字符串,这种数据称之为"静态数据传递"
-
父组件中修改了数据,在子组件中会被同步修改,但是,子组件中的数据修改了,是不会影响到父组件中的数据.
这种情况,在开发时,也被称为"单向数据流"
-
事实上,我们如果要在子组件中把数据传递给父组件,也可以完成的。
通过事件冒泡的方式,进行数据传递
在vue中提供的this.$emit()方法进行给我们传递数据
默认情况下,我们的项目中并没有对axios包的支持,所以我们需要下载安装。
第一步:在项目根目录中使用 npm安装包在命令行下执行安装包的命令:
npm install axios
第二步:在main.js文件中,导入axios并把axios对象 挂载到vue属性中多为一个子对象,这样我们才能在组件中使用。
// The Vue build version to load with the `import` command // (runtime-only or standalone) has been set in webpack.base.conf with an alias. import Vue from 'vue' import App from './App' // 这里表示从别的目录下导入 单文件组件 import axios from 'axios'; // 从node_modules目录中导入包 Vue.config.productionTip = false Vue.prototype.$axios = axios; // 把对象挂载vue中 /* eslint-disable no-new */ new Vue({ el: '#app', components: { App }, template: '<App/>' });
8.1 在组件中使用axios获取数据
<template> <div id="Header" class="header"> {{message}} <p>num: <input type="text" v-model="num"></p> <p>深圳的天气情况: {{weather_info}}</p> </div> </template> <script> export default { name:"Header", // 组件名称,用于以后路由跳转 props:["num"], data(){ // 当前组件中需要使用的数据 return { message:"页面头部", weather_info:"", } }, // 钩子方法,在页面中vue挂在data数据以后,自动执行 created() { // 使用axios发送请求获取数据 this.$http.get("http://wthrcdn.etouch.cn/weather_mini?city=深圳").then(response=>{ console.log(response.data); console.log(response.data.data.ganmao); this.weather_info = response.data.data.ganmao; }).catch(error=>{ }); } } </script> // scoped 表示当前style的样式只作用于当前组件的template代码中,其他地方不会被影响 <style scoped> .header{ height: 100px; line-height: 100px; background-color: #eee; text-align: center; } </style>
使用的时候,因为本质上来说,我们还是原来的axios,所以也会收到同源策略的影响。


浙公网安备 33010602011771号