厦门建模培训,广州做seo整站优化公司,移动端网站设计制作,百度关键词搜索怎么收费Vue脚手架 生命周期 组件化开发
一、今日目标
1.生命周期
生命周期介绍生命周期的四个阶段生命周期钩子声明周期案例
2.综合案例-小黑记账清单
列表渲染添加/删除饼图渲染
3.工程化开发入门
工程化开发和脚手架项目运行流程组件化组件注册
4.综合案例-小兔…
Vue脚手架 生命周期 组件化开发
一、今日目标
1.生命周期
生命周期介绍生命周期的四个阶段生命周期钩子声明周期案例
2.综合案例-小黑记账清单
列表渲染添加/删除饼图渲染
3.工程化开发入门
工程化开发和脚手架项目运行流程组件化组件注册
4.综合案例-小兔仙首页
拆分模块-局部注册结构样式完善拆分组件 – 全局注册
二、Vue生命周期
思考什么时候可以发送初始化渲染请求越早越好什么时候可以开始操作dom至少dom得渲染出来
Vue生命周期就是一个Vue实例从创建 到 销毁 的整个过程。
生命周期四个阶段① 创建 ② 挂载 ③ 更新 ④ 销毁
1.创建阶段创建响应式数据
2.挂载阶段渲染模板
3.更新阶段修改数据更新视图
4.销毁阶段销毁Vue实例 三、Vue生命周期钩子
Vue生命周期过程中会自动运行一些函数被称为【生命周期钩子】→ 让开发者可以在【特定阶段】运行自己的代码 div idapph3{{ title }}/h3divbutton clickcount---/buttonspan{{ count }}/spanbutton clickcount/button/div/divscript srchttps://cdn.jsdelivr.net/npm/vue2/dist/vue.js/scriptscriptconst app new Vue({el: #app,data: {count: 100,title: 计数器},// 1. 创建阶段准备数据// 2. 挂载阶段渲染模板// 3. 更新阶段(修改数据 → 更新视图)// 4. 卸载阶段})/script四、生命周期钩子小案例
1.在created中发送数据 style* {margin: 0;padding: 0;list-style: none;}.news {display: flex;height: 120px;width: 600px;margin: 0 auto;padding: 20px 0;cursor: pointer;}.news .left {flex: 1;display: flex;flex-direction: column;justify-content: space-between;padding-right: 10px;}.news .left .title {font-size: 20px;}.news .left .info {color: #999999;}.news .left .info span {margin-right: 20px;}.news .right {width: 160px;height: 120px;}.news .right img {width: 100%;height: 100%;object-fit: cover;}/stylediv idappulli classnewsdiv classleftdiv classtitle5G商用在即三大运营商营收持续下降/divdiv classinfospan新京报经济新闻/spanspan2222-10-28 11:50:28/span/div/divdiv classrightimg srchttp://ajax-api.itheima.net/public/images/0.webp alt/div/lili classnewsdiv classleftdiv classtitle5G商用在即三大运营商营收持续下降/divdiv classinfospan新京报经济新闻/spanspan2222-10-28 11:50:28/span/div/divdiv classrightimg srchttp://ajax-api.itheima.net/public/images/0.webp alt/div/lili classnewsdiv classleftdiv classtitle5G商用在即三大运营商营收持续下降/divdiv classinfospan新京报经济新闻/spanspan2222-10-28 11:50:28/span/div/divdiv classrightimg srchttp://ajax-api.itheima.net/public/images/0.webp alt/div/li/ul/divscript srchttps://cdn.jsdelivr.net/npm/vue2/dist/vue.js/scriptscript srchttps://cdn.jsdelivr.net/npm/axios/dist/axios.min.js/scriptscript// 接口地址http://hmajax.itheima.net/api/news// 请求方式getconst app new Vue({el: #app,data: {list: []}})/script2.在mounted中获取焦点 stylehtml,body {height: 100%;}.search-container {position: absolute;top: 30%;left: 50%;transform: translate(-50%, -50%);text-align: center;}.search-container .search-box {display: flex;}.search-container img {margin-bottom: 30px;}.search-container .search-box input {width: 512px;height: 16px;padding: 12px 16px;font-size: 16px;margin: 0;vertical-align: top;outline: 0;box-shadow: none;border-radius: 10px 0 0 10px;border: 2px solid #c4c7ce;background: #fff;color: #222;overflow: hidden;box-sizing: content-box;-webkit-tap-highlight-color: transparent;}.search-container .search-box button {cursor: pointer;width: 112px;height: 44px;line-height: 41px;line-height: 42px;background-color: #ad2a27;border-radius: 0 10px 10px 0;font-size: 17px;box-shadow: none;font-weight: 400;border: 0;outline: 0;letter-spacing: normal;color: white;}body {background: no-repeat center /cover;background-color: #edf0f5;}/stylediv classcontainer idappdiv classsearch-containerimg srchttps://www.itheima.com/images/logo.png altdiv classsearch-boxinput typetext v-modelwords idinpbutton搜索一下/button/div/div
/divscript srchttps://cdn.jsdelivr.net/npm/vue2/dist/vue.js/script
scriptconst app new Vue({el: #app,data: {words: }})
/script五、案例-小黑记账清单
1.需求图示 2.需求分析
1.基本渲染
2.添加功能
3.删除功能
4.饼图渲染
3.思路分析
1.基本渲染
立刻发送请求获取数据 created拿到数据存到data的响应式数据中结合数据进行渲染 v-for消费统计 — 计算属性
2.添加功能
收集表单数据 v-model使用指令修饰符处理数据给添加按钮注册点击事件对输入的内容做非空判断发送请求请求成功后对文本框内容进行清空重新渲染列表
3.删除功能
注册点击事件获取当前行的id根据id发送删除请求需要重新渲染
4.饼图渲染
初始化一个饼图 echarts.init(dom) mounted钩子中渲染根据数据试试更新饼图 echarts.setOptions({…})
4.代码准备 !-- CSS only --linkrelstylesheethrefhttps://cdn.jsdelivr.net/npm/bootstrap5.1.3/dist/css/bootstrap.min.css/style.red {color: red!important;}.search {width: 300px;margin: 20px 0;}.my-form {display: flex;margin: 20px 0;}.my-form input {flex: 1;margin-right: 20px;}.table :not(:first-child) {border-top: none;}.contain {display: flex;padding: 10px;}.list-box {flex: 1;padding: 0 30px;}.list-box a {text-decoration: none;}.echarts-box {width: 600px;height: 400px;padding: 30px;margin: 0 auto;border: 1px solid #ccc;}tfoot {font-weight: bold;}media screen and (max-width: 1000px) {.contain {flex-wrap: wrap;}.list-box {width: 100%;}.echarts-box {margin-top: 30px;}}/stylediv idappdiv classcontain!-- 左侧列表 --div classlist-box!-- 添加资产 --form classmy-forminput typetext classform-control placeholder消费名称 /input typetext classform-control placeholder消费价格 /button typebutton classbtn btn-primary添加账单/button/formtable classtable table-hovertheadtrth编号/thth消费名称/thth消费价格/thth操作/th/tr/theadtbodytrtd1/tdtd帽子/tdtd99.00/tdtda hrefjavascript:;删除/a/td/trtrtd2/tdtd大衣/tdtd classred199.00/tdtda hrefjavascript:;删除/a/td/tr/tbodytfoottrtd colspan4消费总计 298.00/td/tr/tfoot/table/div!-- 右侧图表 --div classecharts-box idmain/div/div/divscript srchttps://cdn.jsdelivr.net/npm/echarts5.4.0/dist/echarts.min.js/scriptscript srchttps://cdn.jsdelivr.net/npm/vue2/dist/vue.js/scriptscript srchttps://cdn.jsdelivr.net/npm/axios/dist/axios.min.js/scriptscript/*** 接口文档地址* https://www.apifox.cn/apidoc/shared-24459455-ebb1-4fdc-8df8-0aff8dc317a8/api-53371058* * 功能需求* 1. 基本渲染* 2. 添加功能* 3. 删除功能* 4. 饼图渲染*/const app new Vue({el: #app,data: {},})/script六、工程化开发和脚手架
1.开发Vue的两种方式
核心包传统开发模式基于html / css / js 文件直接引入核心包开发 Vue。工程化开发模式基于构建工具例如webpack的环境中开发Vue。 工程化开发模式优点
提高编码效率比如使用JS新语法、Less/Sass、Typescript等通过webpack都可以编译成浏览器识别的ES3/ES5/CSS等
工程化开发模式问题
webpack配置不简单雷同的基础配置缺乏统一的标准
为了解决以上问题所以我们需要一个工具生成标准化的配置
2.脚手架Vue CLI
基本介绍
Vue CLI 是Vue官方提供的一个全局命令工具
可以帮助我们快速创建一个开发Vue项目的标准化基础架子。【集成了webpack配置】
好处
开箱即用零配置内置babel等工具标准化的webpack配置
使用步骤
全局安装只需安装一次即可 yarn global add vue/cli 或者 npm i vue/cli -g查看vue/cli版本 vue --version创建项目架子vue create project-name(项目名不能使用中文)启动项目yarn serve 或者 npm run serve(命令不固定找package.json)
七、项目目录介绍和运行流程
1.项目目录介绍 虽然脚手架中的文件有很多目前咱们只需人事三个文件即可
main.js 入口文件App.vue App根组件index.html 模板文件
2.运行流程 八、组件化开发
组件化一个页面可以拆分成一个个组件每个组件有着自己独立的结构、样式、行为。
好处便于维护利于复用 → 提升开发效率。
组件分类普通组件、根组件。
比如下面这个页面可以把所有的代码都写在一个页面中但是这样显得代码比较混乱难易维护。咱们可以按模块进行组件划分 总结
组件化的好处是什么
组件的分类
九、根组件 App.vue
1.根组件介绍
整个应用最上层的组件包裹所有普通小组件 2.组件是由三部分构成
语法高亮插件 三部分构成 template结构 有且只能一个根元素script: js逻辑style 样式 (可支持less需要装包) 让组件支持less 1 style标签lang“less” 开启less功能 2 装包: yarn add less less-loader -D 或者npm i less less-loader -D
3.总结
App组件包含哪三部分
十、普通组件的注册使用-局部注册
1.特点
只能在注册的组件内使用
2.步骤
创建.vue文件三个组成部分在使用的组件内先导入再注册最后使用
3.使用方式
当成html标签使用即可 组件名/组件名
4.注意
组件名规范 — 大驼峰命名法 如 HmHeader
5.语法 // 导入需要注册的组件
import 组件对象 from .vue文件路径
import HmHeader from ./components/HmHeaderexport default { // 局部注册components: {组件名: 组件对象,HmHeader:HmHeaer,HmHeader}
}6.练习
在App组件中完成以下练习。在App.vue中使用组件的方式完成下面布局 templatediv classhm-header我是hm-header/div
/templatescript
export default {}
/scriptstyle
.hm-header {height: 100px;line-height: 100px;text-align: center;font-size: 30px;background-color: #8064a2;color: white;
}
/styletemplatediv classhm-main我是hm-main/div
/templatescript
export default {}
/scriptstyle
.hm-main {height: 400px;line-height: 400px;text-align: center;font-size: 30px;background-color: #f79646;color: white;margin: 20px 0;
}
/styletemplatediv classhm-footer我是hm-footer/div
/templatescript
export default {}
/scriptstyle
.hm-footer {height: 100px;line-height: 100px;text-align: center;font-size: 30px;background-color: #4f81bd;color: white;
}
/style7.总结
A组件内部注册的局部组件能在B组件使用吗局部注册组件的步骤是什么使用组件时 应该按照什么命名法
十一、普通组件的注册使用-全局注册
1.特点
全局注册的组件在项目的任何组件中都能使用
2.步骤
创建.vue组件三个组成部分main.js中进行全局注册
3.使用方式
当成HTML标签直接使用 组件名/组件名 4.注意
组件名规范 — 大驼峰命名法 如 HmHeader
5.语法
Vue.component(‘组件名’, 组件对象)
例
// 导入需要全局注册的组件
import HmButton from ./components/HmButton
Vue.component(HmButton, HmButton)6.练习
在以下3个局部组件中是展示一个通用按钮 templatebutton classhm-button通用按钮/button
/templatescript
export default {}
/scriptstyle
.hm-button {height: 50px;line-height: 50px;padding: 0 20px;background-color: #3bae56;border-radius: 5px;color: white;border: none;vertical-align: middle;cursor: pointer;
}
/style7.总结
1.全局注册组件应该在哪个文件中注册以及语法是什么
2.全局组件在项目中的任何一个组件中可不可以使用
十二、综合案例
1.小兔仙首页启动项目演示
2.小兔仙组件拆分示意图 3.开发思路 分析页面按模块拆分组件搭架子 (局部或全局注册) 根据设计图编写组件 html 结构 css 样式 (已准备好) 拆分封装通用小组件 (局部或全局注册) 将来 → 通过 js 动态渲染实现功能