时间:2021-05-26
一、 header 组件开发 之数据的传递
1. App.vue 引入组件
import header from './components/header/header'2. App.vue 中注册组件
export default { components:{ v-header:header } }3. 使用组件
<v-header :sell="sellerObj"></v-header>解释::sell="sellerObj",这里就像一个函数传参一样把sell当成形参,sellerObj就是实参,那么父组件实参是怎么传给子组件的,通过什么传
4. 父组件向子组件传递数据
在父组件中需要将sellerObj作为数据导出,子组件通过props从父组件中获得数据,且要指定数据类型
export default { props:{ // 子组件获取 父组件 数据 sell:{ type:Object // 传递的类型 } } }小结:
5. 调用数据
<div class="logo"> <img :src="sell.avatar" alt="" width='64' height='64'/></div><span class="name">{{sell.name}}</span><div class="description"> {{sell.description + '/' + sell.deliveryTime + '分钟送达'}}</div>细节问题:
support 绑定数据时 加 v-if ='sell.supports'
理由 : 在我们通过axios获取数据前在父组件中创建了一个空的对象sellerObj 先传给子组件,开始 没有数据传送过去就会报错 underfined,加上 v-if ,接受不到数据就不会解析,也就不会报错。
二、 header 组件弹出层(详情)
1.弹出遮罩层
(1) 设置一个状态,判断该状态控制显示隐藏
data (){ return { detailShow:false }}<div v-if="detailShow" class="detail"></div>(2) 绑定点击事件,通过methods 方法改变 状态,控制显隐效果
<div class="bulletin-wrapper" @click="showDetails()" ></div><div class="detail-close" v-if="sell.supports"> <i class="icon-close" @click="hideDetail()"></i></div>methods:{ showDetails () { this.detailShow=true }, hideDetail () { this.detailShow=false }}2. 星级评分
(1) 绑定class 控制星级大小的类型
// 利用 computed 属性<div class="star" :class="starSizeType"></div>(2) 遍历星星的数量
复制代码 代码如下:
<span v-for="itemClass in itemClasses" :class="itemClass" class="star-item" track-by="$index"></span>
(3) 定义常量 控制 每个星的状态
// 类名用变量存起来const LENGTH = 5 // 星星长度const CLS_ON = 'on' // 全星const CLS_HALF = 'half' // 半星const CLS_OFF = 'off'// 空星(4) 通过计算 判断每个span 的类型
itemClasses () { // 返回一个数组为每个span 的类名 (遍历) let spanClassList=[]; // 利用 实参评分来判断 有几颗全星,半星,空星 let scores=( Math.floor(this.score * 2) ) / 2 let intNum= Math.floor(scores); // 全星个数 let HashalfNum= scores % 1 !== 0 // 半星 for(var i=0;i<intNum;i++){ // 遍历全星的span spanClassList.push(CLS_ON) } if(HashalfNum){ // 如果有半星 加类名 spanClassList.push(CLS_HALF) } while(spanClassList.length<LENGTH){// 判断 是否有空星 及个数 spanClassList.push(CLS_OFF) } return spanClassList; }}(5) 通过 动态绑定class 来 给span 加类名
<div class="star" :class="starSizeType"> <span v-for="itemClass in itemClasses" :class="itemClass" class="star-item" track-by="$index"></span></div>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.自定义组件标签(如在主页插入顶栏/侧边栏等)  比如说要将Header.vue插入Home.vue中显示:定义好Header.vue
一、父组件向子组件传递数据在Vue中,可以使用props向子组件传递数据。子组件部分:这是header.vue的HTML部分,logo是在data中定义的变量。
App.vue代码//用transition把切换组件页面的容器包含importHeaderfrom'./components/header'exportdef
使用template实现如下页面(仿饿了么布局)如上图.使用了4个组件,分别是header.vue,goods.vue,ratings.vue,seller.v
本文介绍了vue中component组件的props使用详解,分享给大家,具体如下:props使用方法Vue.component('my-component',