IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 【GitHub案例】axios请求跨域问题——组件间的通信:全局事件总线的实施+工程化的显示 -> 正文阅读

[JavaScript知识库]【GitHub案例】axios请求跨域问题——组件间的通信:全局事件总线的实施+工程化的显示

axios请求跨域跨域域名;
使用es6的模板语法,解析Wie模板字符串

methods:{
   searchUsers(){
       // es6的模板语法,解析Wie模板字符串
       axios.get(`https://api.github.com/search/users?q=${this.keyWord}`).then(
           response=>{
               console.log('请求成功了',response.data.items);
           },
           error=>{
               console.log('请求失败了',error.message);
           }
       )
   }
}

此番做法(gethub后端工程师调好了对接)就可以获取数据;
但是获取的数据在search组件里面:(要传到list组件去)通过全局事件总线,达到信息的传递;
在这里插入图片描述

第一:想好给谁传数据;

首先在main.js里:
安装一个全局事件总线

new Vue({
	el: '#app',
	render: h => h(App),
	beforeCreate(){
		Vue.prototype.$bus = this
	}
})

其次是给list传递信息,那就通过一个生命周期钩子mounted: 绑定一个事件(起个事件名)
要么使用箭头函数,要么直接在menths里配置一个函数

mounted(){
    this.$bus.$on('userList',(users)=>{
        console.log('我是list组件,收到了数据:',users);
    })
}

然后是发送方触发自定义事件:并且传入参数
在这里插入图片描述

之后list组件就要赶紧保存数据

mounted(){
    this.$bus.$on('userList',(users)=>{
        console.log('我是list组件,收到了数据:',users);
        this.users = users;
    })
}

收集而来的数据有很多:但用的的选项不是太多;
然后通过数据绑定完成数据渲染:

<div class="row">
        <div class="card" v-for="p in users" :key="p.login">
            <a :href="p.html_url" target="_blank">
            <img :src='p.avatar_url' style='width: 100px'/>
            </a>
            <p class="card-text" >{{p.login}}</p>
        </div>
</div>

完善github案例

第一种放式:通过全局事件总线来控制几个list数据显示(放在一个事件里面)
但是对于维护和可读性有很大的障碍苦难,不语义化!
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

那么如何将控制信息简易化,(封装成为一个对象信息)

在这里插入图片描述

这样看起来一下就明白这段代码是干甚!要改变什么数据!

methods:{
    searchUsers(){
        //  请求更新List的数据
        this.$bus.$emit('updateUserList',{isFirst:false,isLoading:true,errMsg:'',users:[]});
        // es6的模板语法,解析Wie模板字符串
        axios.get(`https://api.github.com/search/users?q=${this.keyWord}`).then(
            response=>{
                console.log('请求成功了',response.data.items);
                //触发事件
                 this.$bus.$emit('updateUserList',{isLoading:false,errMsg:'',users:response.data.items});
            },
            error=>{
                console.log('请求失败了',error.message);
                this.$bus.$emit('updateUserList',{isLoading:false,errMsg:error.message,users:[]});
                
            }
        )
    }
}

在这里插入图片描述

	data() {
	  return {
	      isFirst:true,//是否为初次展示
	      isLoading:false,//是否处于记载中
	      errMsg:'',//存储错误信息
	      users:[]
	  }
	},
	mounted(){
	  this.$bus.$on('updateUserList',(dataObj)=>{
	      // console.log('我是list组件,收到了数据:',users);
	      this.isFirst = dataObj.isFirst;
	      this.isLoading =dataObj.isLoading;
	      this.errMsg = dataObj.errMsg;
	      // this.users = users;
	      console.log('我是dataobj',dataObj);
	      this.users = dataObj.users
	
	  })

在这里插入图片描述
但是有个地方不明白:
在这里插入图片描述

//改成
v-show='p.length'
//无法显示,是为啥。(优先级还是……)
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-08 18:57:17  更:2022-06-08 18:59:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 8:14:00-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码