- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
PAGE1
PAGE1
前端开发最佳实践:代码复用:4.前端框架:Vue中的单文件组件与代码复用
1介绍Vue单文件组件
1.1单文件组件的概念
Vue.js的单文件组件(SingleFileComponent,简称SFC)是一种独特的组件定义方式,它将组件的模板、脚本和样式封装在一个文件中。这种封装不仅提高了代码的可读性和可维护性,还使得组件的开发更加模块化和高效。
1.2单文件组件的结构
一个典型的Vue单文件组件由以下三部分组成:
模板(Template):使用template标签定义,包含HTML、Vue指令和组件。
脚本(Script):使用script标签定义,包含组件的逻辑和数据。
样式(Styles):使用style标签定义,可以是全局样式,也可以通过scoped属性限制为局部样式。
1.2.1示例代码
!--HelloWorld.vue--
template
divclass=hello
h1{{msg}}/h1
button@click=changeMessageChangeMessage/button
/div
/template
script
exportdefault{
name:HelloWorld,
data(){
return{
msg:WelcometoVue.js
}
},
methods:{
changeMessage(){
this.msg=MessageChanged!
}
}
}
/script
stylescoped
.hello{
color:#42b983;
}
/style
1.2.2代码解析
模板:定义了一个包含标题和按钮的简单布局,按钮绑定了changeMessage方法。
脚本:定义了组件的逻辑,包括数据msg和方法changeMessage。
样式:使用scoped属性限制样式仅在当前组件中生效,避免了全局样式污染。
1.3单文件组件的优势
代码组织:将组件的模板、逻辑和样式集中在一个文件中,便于理解和维护。
局部样式:通过scoped属性,可以轻松实现样式隔离,避免命名冲突。
代码复用:组件可以被多次复用,减少代码重复,提高开发效率。
开发工具支持:许多Vue开发工具和编辑器提供了对SFC的良好支持,如语法高亮、代码提示等。
构建优化:构建工具如Webpack可以更好地处理SFC,进行代码分割和优化。
1.4代码复用示例
1.4.1创建可复用组件
假设我们有一个用于显示用户信息的组件:
!--UserInfo.vue--
template
divclass=user-info
h2{{}}/h2
p{{user.email}}/p
/div
/template
script
exportdefault{
name:UserInfo,
props:{
user:{
type:Object,
required:true
}
}
}
/script
stylescoped
.user-info{
border:1pxsolid#ccc;
padding:10px;
}
/style
1.4.2在项目中复用组件
在其他组件中,我们可以轻松地导入和使用UserInfo组件:
!--App.vue--
template
divid=app
UserInfo:user=user1/
UserInfo:user=user2/
/div
/template
script
importUserInfofrom./components/UserInfo.vue
exportdefault{
name:App,
components:{
UserInfo
},
data(){
return{
user1:{
name:Alice,
email:alice@
},
user2:{
name:Bob,
email:bob@
}
}
}
}
/script
1.4.3代码解析
UserInfo.vue:定义了一个接受user属性的组件,用于显示用户信息。
App.vue:在主组件中导入并使
有哪些信誉好的足球投注网站
文档评论(0)