vue 从组件更改 div

Posted

技术标签:

【中文标题】vue 从组件更改 div【英文标题】:vue change div from component 【发布时间】:2022-01-12 19:21:36 【问题描述】:

html

    <div class='wrapper'>
      <div class='custom'>
        <div class='item'> 1</div>
        <div class='item'> 2 </div>
        <div class='item'> 3 </div>
      </div>
      <component-vue />
    </div>

Vue

    methods: 
      doSomething() 
       document.querySelector('.custom).innerhtml = /new items
     
    

我的问题是,这是更改外部 div 的唯一方法吗?我需要更改items,新的来自api。也许还有另一种方式?如果只是通过innerHTML,那我该如何实现呢?

【问题讨论】:

您可以使用迭代器 v-foritems 数据。 【参考方案1】:

例如,

<div class="item" v-for="(item, index) in items" :key="index"></div>
data() 
   return 
      items: []
   
,
methods: 
    doSomething() 
       // Fetch data from api and load
       this.items = res.data
   

编辑

<div class='custom' v-html="dataHtml"></div>
data() 
   return 
      dataHtml: `
      <div>Initial html</div>
      `
   
,
methods: 
    doSomething() 
       // Fetch data from api and load
       this.dataHtml = createHtml(res.data) // Fictional method to parse data and transform to html f.e.
   

【讨论】:

显然,我没有很好地解释我需要什么。对不起。 :c html 是用ruby ​​on rails 编写的,我想从组件中影响custom 类。我们为 SEO 保留布局,然后,如果我单击过滤器中的按钮,我们将重新绘制 html 然后试试v-html。我会补充回答。 我是否理解正确,你需要在一般的vue中写这个,它不会工作在compoent-vue 如果 vue.js 只是在component vue 中,我的回复对它不起作用,你只能使用 vainilla。但是如果 vue 应用是在父级中初始化的,那就可以了。

以上是关于vue 从组件更改 div的主要内容,如果未能解决你的问题,请参考以下文章

VueJS子组件按钮更改父类

如何在范围外更改 vue.js 组件数据

vue 高级属性父组件provide向子组件发送数据,子组件通过inject接收数据

Vue.js 设置组件数据

为啥 Vue 更新所有组件,而不仅仅是 v-for 中更改的组件?

如何在 Vue 中访问数组组件并更改其样式?