首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Vue不呈现获取的html

Vue不呈现获取的html
EN

Stack Overflow用户
提问于 2022-07-16 13:04:47
回答 1查看 103关注 0票数 0

我在shopify中使用vue,并且正在编写一个集合页面。当我单击一个过滤器时,它是一个href,它更新url并重新加载页面。

所以我有一个产品网格

代码语言:javascript
运行
复制
<div class="grid-wrapper">
  <template v-for="(product, index) in collection.products">
    <div class="product-item"></div>
  </template>
</div>

我的想法是在fetch中使用相同的url,这样页面就不会重新加载。

是我干的

代码语言:javascript
运行
复制
fetch('/collections?variant=black')
  .then(res => res.text())
  .then(html => new DOMParser().parseFromText(html, 'text, html'))
  .then(data => {
    document.querySelector('.grid-wrapper').innerHTML = data.querySelector('.grid-wrapper').innerHTML
  })

这不起作用,因为我得到了实际的<template v-for…>,因为新的innerHTML和vue没有接管。我怎么解决这件事

在shopify中,我像这样转换了对象

代码语言:javascript
运行
复制
const collection = (() => {
  const collection = {{ collection | json }}
  const products = {{ collection.products | json }}
  collection.products = products
  return collection
})();

然后在我的虚拟世界里

代码语言:javascript
运行
复制
new Vue.createApp({
  data() {
    collection: collection
  }
}).mount('#app')
EN

回答 1

Stack Overflow用户

发布于 2022-07-16 14:15:54

您使用传统的直接操作DOM的JavaScript方式来处理这个问题。在Vue中,我们设置了可以由模板呈现的状态。

相反:

  1. 创建一个data属性来存储状态
  2. methods下,编写一个函数来获取数据,然后更新组件data
  3. 调用组件created钩子中的函数
  4. 在您的template中,呈现结果
    • 别忘了先检查一下它的存在,用v-if
    • 可以使用v-for进行迭代,并呈现列表。

这是一个工作演示

我无法访问您的API端点,因此为了演示目的,只需使用GitHub API来获取和呈现Vue.js组织中所有repos的列表。

看上去是这样的:

代码语言:javascript
运行
复制
Vue.config.devtools = false;
    Vue.config.productionTip = false;
    new Vue({
      el: '#app',
      name: 'dbzx10299-demo',
  data() {
    return {
      loaded: false,
      response: null,
    }
  },
  methods: {
    fetchData() {
      const demoEndpoint = 'https://api.github.com/orgs/vuejs/repos';
      fetch(demoEndpoint)
      .then(response => response.json())
      .then(data => {
        this.response = data;
        this.loaded = true;
      })
    },
  },
  mounted() {
    this.fetchData();
  },
    })
代码语言:javascript
运行
复制
<script src="https://unpkg.com/vue@2.x/dist/vue.js"></script>

<div id="app">
<div class="hello">
  <h2>Vue Repo List - Data fetching example</h2>
  <div v-if="!loaded">Loading...</div>
  <ul v-else>
    <li v-for="(repo, index) in response" :key="index">
      <a :href="repo.html_url" :title="repo.description" target="_blank">
        {{ repo.name }}
      </a>
      <i>★ {{ repo.stargazers_count }}</i>
    </li>
  </ul>
</div>
</div>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73004461

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档