核心内容摘要
SpringBoot校园新闻网站毕设源码免费项目
文章目录Ⅰ. 组件及组件化
为什么需要组件
思考
解决方案
组件及组件化
组件
组件化
根组件 App.vue
根组件
组件是由三部分构成
组件的使用
创建组件
导入组件
注册组件
使用组件
练习
组件的全局注册
步骤
使用组件与局部组件一样
注意
语法
练习Ⅰ. 组件及组件化
为什么需要组件
思考以可折叠面板为例现要展示3个如何操作可折叠面板案例的代码script setupimport{ref}fromvueconstvisibleref(false)/scripttemplateh3可折叠面板/h3divclasspaneldivclasstitleh4自由与爱情/h4spanclassbtnclickvisible !visible/span/divdivclasscontainerv-showvisiblep生命诚可贵/pp爱情价更高。
/pp若为自由故/pp两者皆可抛。
/p/div/div/templatestyle langscssbody{background-color:#ccc;}#app{width:400px;margin:20px auto;background-color:#fff;border:4px solid green;border-radius:1em;box-shadow:3px 3px 3pxrgba(0,0,0,
0.
;padding:1em 2em 2em;}#app h3{text-align:center;}.panel{.title{display:flex;justify-content:space-between;align-items:center;border:1px solid #ccc;padding:01em;}.title h4{line-height:2;margin:0;}.container{border:1px solid #ccc;padding:01em;border-top-color:transparent;}.btn{cursor:pointer;}}/style
解决方案把需要复用的一段标签抽离并封装到一个单独的vue文件里连同相关JS和CSS放到一起哪里要用这个组件哪里导入当做标签使用即可新建一个src/components/MyPanel.vue文件script setupimport{ref}fromvueconstvisibleref(false)/scripttemplatedivclasspaneldivclasstitleh4自由与爱情/h4spanclassbtnclickvisible !visible/span/divdivclasscontainerv-showvisiblep生命诚可贵/pp爱情价更高。
/pp若为自由故/pp两者皆可抛。
/p/div/div/templatestyle langscssscoped.panel{.title{display:flex;justify-content:space-between;align-items:center;border:1px solid #ccc;padding:01em;}.title h4{line-height:2;margin:0;}.container{border:1px solid #ccc;padding:01em;border-top-color:transparent;}.btn{cursor:pointer;}}/style然后在App.vue导入并使用该组件script setup// 导入importMyPanelfrom./components/MyPanel.vue/scripttemplateh3可折叠面板/h3!--使用--MyPanel/MyPanel/MyPanel//templatestylebody{background-color:#ccc;}#app{width:400px;margin:20px auto;background-color:#fff;border:4px solid green;border-radius:1em;box-shadow:3px 3px 3pxrgba(0,0,0,
0.
;padding:1em 2em 2em;}#app h3{text-align:center;}/style
组件及组件化
组件组件是一个独立的、可复用的Vue实例也是一段独立的 UI 视图代码上体现在是一个独立的.vue文件包含JS HTML CSS三部分组成。
类似乐高和积木一样我们可以通过任意的乐高或积分进行组合拼装成我们需要的成品。
组件化定义一种代码的开发思想体现在一个页面可以拆分成一个个组件每个组件有着自己独立的结构、样式、行为通过组件的组合与拼装形成一个完整的页面本质是代码的一种拆分思想化大为小、化繁为简、分而治之。
好处各自独立、便于复用比如下面这个页面可以把所有的代码都写在一个页面中但是这样显得代码比较混乱难以维护。
我们可以按模块进行组件拆分
根组件App.vue
根组件根组件是整个应用最上层的组件包裹所有普通小组件如下图所示
组件是由三部分构成templateHTML 结构scriptJS 逻辑styleCSS 样式可支持less/scss需要装包让组件支持less/scssstyle标签langless/scss开启less/scss功能装包npm i less less-loader -D或者npm i sass -D
组件的使用组件的一系列场景命名规范如下所示场景✅推荐写法可选写法说明文件名MyHeader.vuemy-header.vue官方推荐 PascalCase和类名一样清晰import 引入import MyHeader from ‘./MyHeader.vue’import Haha from ‘./MyHeader.vue’变量名随意但最好和文件名一致便于阅读局部注册components: { MyHeader }components: { Haha }名字和模板里的标签要对应模板 (SFC 内部)Vue 自动识别两种形式HTML 文件直接写 (非 .vue)❌ 不支持HTML 标签不区分大小写必须用短横线
创建组件新建.vue文件编写组件的三部分代码
导入组件在需要的vue文件中的script setup中导入需要的组件即可注意导入的组件对象名称推荐保持和文件名一致。
import组件对象from相对路径// 例子importMyPanelfrom./components/MyPanel.vue
注册组件注意局部组件无需注册全局组件要在main.js中注册。
之所以局部组件不需要注册是因为vue3中script setup自动完成了局部注册如果是vue2或者普通的script的话则需要手动注册局部组件如下面所示scriptimportMyHeaderfrom./components2/MyHeader.vue// 如果是 vue2 或者普通的 script 的话则需要手动注册局部组件exportdefault{components:{MyHeader}}/scripttemplatemy-header/my-header/template