案例知识点

  1. 兄弟组件儿的通信     使用了Pubsub    订阅与发布
  2. ajax数据请求    获取前   获取中   获取后   获取为空    获取异常
  3. 获取成功后显示数据给到  原先定义号的 jsonData     users

    vue Search案例 消息订阅pubsub与ajax

    pubsub消息订阅组件,便于兄弟组件间调用

    npm install --save pubsub-js

    App.vue

     <template>
    <div id="app">
    <div class="container">
    <Search/>
    <users-main/>
    </div>
    </div>
    </template> <script>
    import Search from './components/Search.vue'
    import Main from './components/Main.vue'
    export default{
    components:{
    Search,
    // 内部定义的关键词名称 不可以使用 所以赋值一个名字
    UsersMain:Main }
    };
    </script> <style type="stylus"> </style>

    Main.vue

    // 由于请求状态在Main中,ajax写在main中以便同步更新4个状态。 写在search中不便更新状态。
    <template>
    <div>
    <!-- 搜索我有四种状态 -->
    <!-- 1.搜索之前 -->
    <h2 v-if="firstView">输入用户名搜索</h2>
    <!-- 2.搜索中.... -->
    <h2 v-if="loading">GitData...</h2>
    <!-- 4.没有搜索到 -->
    <h2 v-if="overNull">该关键字没有搜索到Data...</h2>
    <!-- 3.搜索失败error -->
    <h2 v-if="errorMsg">{{errorMsg}}</h2>
    <div v-else class="row" v-for="(user,index) in users" :key="index" :index="index">
    <div class="card">
    <a :href="user.url" target="_blank">
    <img :src="user.avatar_url" style='width: 100px'/>
    </a>
    <p class="card-text">{{user.name}}</p>
    </div>
    </div>
    </div>
    </template> <script type="text/ecmascript-6">
    import PubSub from 'pubsub-js'
    import axios from 'axios'
    export default{
    data(){
    return {
    firstView: true,
    loading:false,
    overNull:false,
    errorMsg: '',
    users:null
    // [
    // {url:'',avatar_url:'',name:''},
    // ] }
    },
    mounted(){
    // 是否在此发ajax消息 是点击search后
    // 订阅搜索的消息
    PubSub.subscribe('search',(msg,searchName)=>{
    const url = `https://api.github.com/search/users?q=${searchName}`
    // 更新失败(请求中)
    this.firstView = false
    this.loading = true
    this.overNull = false
    alert('请求中')
    // 发送ajax请求
    axios.get(url).then(response=> {
    // 获取数据 data
    const result = response.data
    // data中的items 里面有图片的路径 名称
    const users = result.items.map(item=>({
    url:item.html_url,
    avatar_url:item.avatar_url,
    name: item.login
    }))
    if(users.length !== 0){
    console.log(users)
    } // 成功更新状态(成功)
    this.loading = false
    this.users = users if(users.length == 0){
    this.overNull = true
    }
    // 失败更新状态(失败)
    }).catch(error=>{
    this.loading = false
    this.errorMsg = '请求失败'
    }) })
    } };
    </script> <style type="stylus" rel="stylesheet/stylus"> .card {
    float: left;
    width: 33.333%;
    padding: .75rem;
    margin-bottom: 2rem;
    border: 1px solid #efefef;
    text-align: center;
    } .card > img {
    margin-bottom: .75rem;
    border-radius: 100px;
    } .card-text {
    font-size: 85%;
    } </style>

    Search.vue

     <template>
    <div>
    <section class="jumbotron">
    <h3 class="jumbotron-heading">Search Github Users</h3>
    <div>
    <input type="text" placeholder="enter the name you search" v-model="searchName"/>
    <button @click="search">Search</button>
    </div>
    </section>
    </div>
    </template> <script type="text/ecmascript-6">
    import PubSub from 'pubsub-js'
    export default{
    data(){
    return {
    searchName:''
    }
    },
    methods:{
    search(){
    const searchName = this.searchName.trim()
    if(searchName){
    // 发布搜索的消息
    PubSub.publish('search',searchName)
    }
    }
    } };
    </script> <style type="stylus" rel="stylesheet/stylus"> </style>

Vue--- Vue(Pubsub + Ajax) 数据交互的更多相关文章

  1. Atitit vue.js 把ajax数据 绑定到form表单

    Atitit vue.js 把ajax数据 绑定到form表单 1.1. 使用场景:主要应用在编辑与提交场合..1 1.2. 绑定数据到form控件,可以使用jquery,不过vue.js更加简单1 ...

  2. 弹出层和ajax数据交互

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs& ...

  3. Struts2与Ajax数据交互

    写在前面: ajax请求在项目中常常使用,今天就平时掌握的总结一下,关于使用ajax请求到Struts2中的action时,前台页面与后台action之间的数据传递交互问题. 这里我主要记录下自己所掌 ...

  4. ajax数据交互

    目录 一.ORM查询优化 1-1. only与defer 1-2. select_related与prefatch_related 二.MTV与MVC模型 三.choices参数 四.AJAX 4-1 ...

  5. django建立管理系统之五----单页ajax数据交互

    ajax数据提交: 需求: 1. 点击ajax方式提交后数据提交到后台数据库,并且在前台实现数据更新 a.可以用刷新页面来实现数据页面的更新 对应的html,实现局部刷新(可以用刷新页面实现,例如 $ ...

  6. vue.js 三(数据交互)isomorphic-fetch

    至于fetch的介绍,在这里就不多说了,官方和网络上的说明不少 之前使用jquery的Ajax朋友,可以尝试一下使用一下这个新的api 推荐使用isomorphic-fetch,兼容Node.js和浏 ...

  7. ajax数据交互(arcgis server)

    通过ajax来调用服务器map数据,来实现搜索功能. 效果: 1.我要搜索下中国移动的地理信息: 2.会搜出17条消息,然后把他们分页显示,一页6条: 3.每一页的6天数据,会在map生成一个6条ma ...

  8. jq ajax数据交互

    get 与 post 的区别 了解和使用 get和post是HTTP与服务器交互的方式, 说到方式,其实总共有四种:put,delete,post,get. 他们的作用分别是对服务器资源的增,删,改, ...

  9. jSon和Ajax登录功能,ajax数据交互案例

    ajax实例,检测用户与注册 检测用户名是否被占用: 在用户填写完用户名之后,ajax会异步向服务器发送请求,判断用户名是否存在 首先写好静态页面: index.html <!DOCTYPE h ...

  10. EChats+Ajax之柱状图的数据交互

    原文链接:https://blog.csdn.net/qq_37936542/article/details/79723710 一:下载 echarts.min.js 选择完整版进行下载,精简版和常用 ...

随机推荐

  1. mvc中RedirectToAction()如何传参?

    今天在做一个功能的时,使用RedirectToAction()需要从这里传几个参数,从网上查了一下,这样解决.真好. Return RedirectToAction("Index" ...

  2. C++里将string类字符串(utf-8编码)分解成单个字(可中英混输)

    最近在建词典,使用Trie字典树,需要把字符串分解成单个字.由于传入的字符串中可能包含中文或者英文,它们的字节数并不相同.一开始天真地认为中文就是两个字节,于是很happy地直接判断当前位置的字符的A ...

  3. BZOJ3033: 太鼓达人(欧拉回路)

    题意 题目链接 Sol 第一问的答案是\(2^M\),因为每个位置只有\(0 / 1\)两种情况,最优情况下一定是每个位置代表着一个长度为\(K\)的字符串 考虑相邻两个字符串之间的转化,第二个字符串 ...

  4. java线程安全问题原理性分析

    1.什么是线程安全问题? 从某个线程开始访问到访问结束的整个过程,如果有一个访问对象被其他线程修改,那么对于当前线程而言就发生了线程安全问题:如果在整个访问过程中,无一对象被其他线程修改,就是线程安全 ...

  5. 转:HTML中让图片滚动的<marquee>标签的使用方法

    实例: <marquee id="affiche" align="left" behavior="scroll" bgcolor=&q ...

  6. 001Angular2环境准备

    01.安装Node.js 和 npm 安装完成后,在命令行依次使用node -v 和 npm -v可以看到版本号. 02.安装cnpm npm需要连接谷歌服务器,国内不能正常使用,需安装cnpm.命令 ...

  7. Android SharedPreferences存储数据

    SharedPreferences是Android中最容易理解的数据存储技术,实际上SharedPreferences处理的就是一个key-value(键值对)SharedPreferences常用来 ...

  8. Daemon 自更新

    NSTask *task = [[NSTask alloc] init]; [task setLaunchPath:@"usr/bin/dpkg"]; [task setArgum ...

  9. matlab练习程序(随机粒子切换特效)

    视频制作软件中一般都会有相邻帧切换的特效,我过去用过vagas好像就有很多切换特效. 我想这个也算是其中一种吧,虽然我不确定实际中到底有没有这种切换. 实际上我只是下班后太无聊了,写着玩的,没什么高深 ...

  10. 面试题之-------使用TCP/UDP协议的常见协议及端口号

    使用TCP协议的常见端口主要有以下几种: (1) FTP:定义了文件传输协议,使用21端口.常说某某计算机开了FTP服务便是启动了文件传输服务.下载文件,上传主页,都要用到FTP服务. (2) Tel ...