拾月拾 2022-10-19 10:37 采纳率: 55.6%
浏览 51
已结题

为什么用v-html获取到的数据展现到前端变成“{}”

问题遇到的现象和发生背景

为什么用v-html获取到的数据展现到前端变成“{}”这样,但是控制台是有显示数据的

用代码块功能插入代码
classifyId: function  (article_classify_id) {
                    let id = article_classify_id;
                    let classify = async  function(id){
                        let classify_arr_name =
                            axios.get("selectClUpIdName?id=" + article_classify_id).then(function (response) {
                                return response.data;
                            })
                        console.log(classify_arr_name);
                        let name = await classify_arr_name;
                        return name;
                    }
                    console.log(classify(id))
                    return classify(id);
                }

运行结果及报错内容

img

  • 写回答

3条回答 默认 最新

  • hfhan_872914334 2022-10-19 15:26
    关注

    方式方法就错了
    首先,你用v-html去渲染,他渲染的是什么,是v-html的值,也就是你写的classifyId函数的值,classifyId是一个异步函数,他的值是什么,它永远是一个promise啊,可是你要把它变成同步函数,他就获取不到你想要的值了
    一般异步获取值都是在页面渲染前先用一个变量预占位进行渲染,异步获取对应的值然后更新到这个变量上,页面上会自己进行更新的,比如下面这样

    data.forEach(item => {
      item.classifyHtml = '' // 预占位变量
      this.classifyId(item.article_classify_id).then(name => this.$set(item, 'classifyHtml', name))
    })
    

    页面就是用classifyHtml 渲染就行:v-html="a.classifyHtml"

    最后,这种循环调用接口的做法也是不可取的,浏览器所能同时发起的服务请求是有数量限制的,如果data数据量很大会造成网络堵塞的,而且也是性能的一种浪费,这种需求肯定需要在服务端去获取,然后一把返回给前台

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 10月27日
  • 已采纳回答 10月19日
  • 创建了问题 10月19日

悬赏问题

  • ¥17 pro*C预编译“闪回查询”报错SCN不能识别
  • ¥15 微信会员卡接入微信支付商户号收款
  • ¥15 如何获取烟草零售终端数据
  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 HLs设计手写数字识别程序编译通不过
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 TYPCE母转母,插入认方向