父组件中当点击搜索的时候请求接口,然后把新的数据用 computed 传递给子组件

<van-search
v-model="onSeachPhone"
show-action
placeholder="请输入电话号码后四位"
@search="onSearchPhone"
@clear="onCancelPhone"
>
<template #action>
<div @click="onSearchPhone">查询</div>
</template>
</van-search>
<seachPhone @history ="history" :phoneLists ="phoneLists" @PHides='PHides' :phoneHide='phoneHide' />
    <script>
     export default {
    components:{
        seachPhone,
   
    },
    data(){
        return{
            // maxDate: new Date(2900, 0, 31),
        
          
            phoneHide:false,
            phoneList:[],
            typeHide:false,
         
       
            
        }
    },
   
    computed:{
      phoneLists(){
        return this.phoneList
      },
    
    },
    methods:{
        history(val){
             this.userName = val.guestname;//客人姓名
             this.phone = val.telphone;//电话号码
             this.phoneHide = false;
        },
          PHides(val){
            console.log(val)
            this.phoneHide = val;
        },
        onSearchPhone(a){
            if(this.onSeachPhone != ''){
                console.log(this.onSeachPhone)
                SearchWine({
                    tel:this.onSeachPhone 
                })
                .then((e)=>{
                    if( e.code ==  ){
                        if(e.data.length >  ){
                            this.phoneList = e.data;
                            this.phoneHide = true;
                        }
                    }else{
                        this.$msg({
                            text:e.msg,
                            type:'info'
                        })
                    }
                })
            }else{
                this.$msg({
                    text:'都没输入你在摁什么?',
                    type:'info'
                })
            }
            </script>


 子组件中用watch 监听 phoneList 改变然后从新赋值在子组件点击的时候利用 this.$emit('方法名',参数)。   
<template>
<div class="">
<div class="card_model" v-if="phoneHide">
<div class="card-bock" >
<div class="titles">
<span class="model_juese">存酒记录</span>
<img @click="PHides" class="right imgright" src="@/assets/img/btn_close.png" alt="">
</div>
<div class="cardconter">
<div class="spanul">
<span>记录</span>
<ul class="ulactive van-tree-select__nav">
<li v-for="(a,b) in phoneListsaa" :key="b" @click="history(a)">
<span class="left">名字:{{a.guestname}}</span>
<span class="right">电话:{{a.telphone}}</span>
</li> </ul>
</div>
<!-- <div class="spanul">
<span>会员</span>
<ul class="ulactive van-tree-select__nav">
<li> 11111</li>
</ul>
</div> -->
</div>
</div>
</div>
</div>
</template>
<script>
export default {
props:{
phoneHide:{
type:Boolean,
default:()=>{}
},
phoneLists:{
type:Array,
default:()=>[]
}
}, watch:{
phoneLists(a){
this.phoneListsaa = a
}
},
methods:{
PHides(){
this.$emit('PHides',false)
},
history(a){
this.$emit('history',a)
}
},
data(){
return{
phoneListsaa: this.phoneLists,
shows:true,
}
}
}
</script>
<style scoped>
.spanul span{
padding: 6px;
min-height: 34px;
line-height: 34px;
display: block;
}
.spanwindt{
width: 30.333%;
display: inline-block;
text-align: center;
border:1px solid rgba(66,139,202, .3);
margin: 1%;
color:#428BCA;
min-height: 34px;
line-height: 34px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis }
.ulactive li:nth-child(odd){
background: rgba(66, 139, 202, .03);
}
.bgccc{
background: #428BCA;
color: #fff;
}
.model_juese{
font-size: 16.2px;
margin: 0 auto;
display: block;
text-align: center;
border-bottom: 1px solid rgba(235,235,235,.6);
padding-bottom: 15px;
padding-top: 15px;
}
.card_model{
position: fixed;
background: rgba(0,0,0,.7);
z-index: 888;
width: 100%;
display: block;
top: 0;
left: 0;
bottom: 0;
}
.radiobtn{
width: 175px;
height: 40px;
color: #fff;
background: #428BCA;
display: block;
text-align: center;
margin: 0 auto;
border:none;
border-radius: 6px;
position: absolute;
bottom: 5%;
left: 24%;
/* margin-top: 231px; */
}
.cardconter{
position: relative;
width: 100%;
}
.imgright{
position: absolute;
right: 4%;
top: 4%;
display: block;
}
.card-bock{
width: 90%;
height: 500px;
background: #fff;
display: block;
margin: 0 auto;
position: relative;
border-radius: 10px;
top: 6%;
overflow-y: auto;
}
.ulactive{
height: 200px; }
.ulactive li{
padding: 6px;
min-height: 34px;
line-height: 34px;
border-bottom: 1px solid rgba(235,235,235,.3);
background: #F7F7F7FF;
}
.ulactive .activeLI{
background: rgba(66,139,202, .3);
color: #428BCA;
}
.van-search__content{
border: 1px solid #F7F8FA;
background: #fff;
}
.van-search .van-cell{
background: #fff;
}
.ulright{
background: #ffffff;
width: 65%;
display: inline-block;
float: right;
position: fixed;
right: 5%;
font-size: 13px;
height:71%;
overflow-y: auto;
}
.rightconter li {
color: #666666;
font-size: 13px;
font-family: PingFang-SC-Medium;
padding: 6px;
line-height: 34px;
min-height: 34px;
width: 95.5%;
position: relative;
}
.bgcolor .listli {
padding: 15px 15px;
}
.bgcolor li:nth-child(odd){
background: rgba(66, 139, 202, .03);
}
.bgcolor li:nth-child(even){
background: #FFFFFFFF;
}
</style>
    

vue watch/ computed的应用(做一个简单的父子之间的传递/电话号码的搜索)的更多相关文章

  1. MUI框架-05-用MUI做一个简单App

    MUI框架-05-用MUI做一个简单App MUI 是一个前端框架,前端框架就像 Bootstrap,EasyUI,Vue ,为了做 app 呢,就有了更加高效的 MUI,我觉得前端框架有很多,也没有 ...

  2. Vue.js 入门:从零开始做一个极简 To-Do 应用

    Vue.js 入门:从零开始做一个极简 To-Do 应用 写作时间:2019-12-10版本信息:Vue.js 2.6.10官网文档:https://cn.vuejs.org/ 前言  学习 Vue ...

  3. 使用ant design vue的日历组件,实现一个简单交易日与非交易日的切换

    使用ant design vue的日历组件,实现一个简单交易日与非交易日的切换 需求: 日历区分交易日.非交易日 可以切换面板查看整年交易日信息 可以在手动调整交易日.非交易日 演示实例 序--使用软 ...

  4. 【Bugly干货分享】一起用 HTML5 Canvas 做一个简单又骚气的粒子引擎

    Bugly 技术干货系列内容主要涉及移动开发方向,是由Bugly邀请腾讯内部各位技术大咖,通过日常工作经验的总结以及感悟撰写而成,内容均属原创,转载请标明出处. 前言 好吧,说是“粒子引擎”还是大言不 ...

  5. 使用React并做一个简单的to-do-list

    1. 前言 说到React,我从一年之前就开始试着了解并且看了相关的入门教程,而且还买过一本<React:引领未来的用户界面开发框架 >拜读.React的轻量组件化的思想及其virtual ...

  6. 【 D3.js 入门系列 --- 3 】 做一个简单的图表!

    前面说了几节,都是对文字进行处理,这一节中将用 D3.js 做一个简单的柱形图. 做柱形图有很多种方法,比如用 HTML 的 div 标签,或用 svg . 推荐用 SVG 来做各种图形.SVG 意为 ...

  7. 一起用HTML5 canvas做一个简单又骚气的粒子引擎

    前言 好吧,说是"粒子引擎"还是大言不惭而标题党了,离真正的粒子引擎还有点远.废话少说,先看demo 本文将教会你做一个简单的canvas粒子制造器(下称引擎). 世界观 这个简单 ...

  8. Jmeter初步使用二--使用jmeter做一个简单的性能测试

    经过上一次的初步使用,我们懂得了Jmeter的安装与初步使用的方法.现在,我们使用Jmeter做一个简单的性能测试.该次测试,提交的参数不做参数化处理,Jmeter各元件使用将在介绍在下一博文开始介绍 ...

  9. 用EF DataBase First做一个简单的MVC3报名页面

    使用EF DataBase First做一个简单的MVC3报名网站 ORM(Object Relational Mapping)是面向对象语言中的一种数据访问技术,在ASP.NET中,可以通过ADO. ...

随机推荐

  1. 最简单的VScode Python 开发环境配置以及中文化

    前置条件 Python 3.X(2020年了,建议使用Python3.X版本) 一.下载VSCode VSCode官方下载链接 由于安装过程是中文界面,此处略过. 二.VSCode中文化 不需要配置什 ...

  2. UWP 自定义密码框控件

    1. 概述 微软官方有提供自己的密码控件,但是控件默认的行为是输入密码,会立即显示掩码,比如 *.如果像查看真实的文本,需要按查看按钮. 而我现在自定义的密码控件是先显示你输入的字符2s,然后再显示成 ...

  3. xctf-web fakebook

    点join注册账号 进入view.php发现参数no存在sql注入,但是过滤了select关键字,用内联注释绕过 在users表的data字段发现了用序列化存储的用户信息 然后就卡在这里了....看了 ...

  4. python中的and与or

    一.问题起源: main=None main=main or sys.modules["__main__"].main main返回的是后面一个值,即 sys.modules[&q ...

  5. clion 如何执行外部文件

    https://blog.csdn.net/he_yang_/article/details/96644480 这里这里

  6. 05_MySQL数据库

    学于黑马和传智播客联合做的教学项目 感谢 黑马官网 传智播客官网 微信搜索"艺术行者",关注并回复关键词"软件测试"获取视频和教程资料! b站在线视频 软件测试 ...

  7. 线程_进程间通信Queue合集

    # Queue的工作原理 from multiprocessing import Queue q = Queue(3)#初始化一个Queue对象,最多可接收3条put消息 q.put("In ...

  8. NodeJS 极简教程 <1> NodeJS 特点 & 使用场景

    NodeJS 极简教程 <1> NodeJS 特点 & 使用场景 田浩 因为看开了所以才去较劲儿.   1. NodeJS是什么 1.1 Node.js is a JavaScri ...

  9. C/C++编程笔记:一张思维导图,带你总结C语言全部知识点!

    很多小伙伴想要好好地学习一下C语言的知识,但是又不知道怎么学,应该学哪一些C语言的知识,笔者在网上看到了这一张C语言的比较完善的C语言的学习路线图,有兴趣的小伙伴可以保存起来哈! C语言是面向过程的, ...

  10. ARC 093 F Dark Horse 容斥 状压dp 组合计数

    LINK:Dark Horse 首先考虑1所在位置. 假设1所在位置在1号点 对于此时剩下的其他点的方案来说. 把1移到另外一个点 对于刚才的所有方案来说 相对位置不变是另外的方案. 可以得到 1在任 ...