微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

vue中可以用函数的返回来定义一个div的样式吗?

如何解决vue中可以用函数的返回来定义一个div的样式吗?

嘿,我想在我的 div 的 v-bind:style 中调用函数 textposit,它使用 prop textpos 作为参数。函数的返回应该根据参数值改变div的样式。

<div class="container"  :style=" textposit(textpos) ">
       <p class="headline">{{ headline }}</p>
       <p class="text">{{ text }}</p>
</div>

这是我的脚本:

export default {
    name: 'page',components: {
    },props:{
        headline: {
            type: String,},text: {
            type: String,img: {
            type: String,align:{
            type: String,default: "center",textpos:{
            type: String,default: "left",textrows:{
            type: Number,default: 1,}
    },methods:{
      textposit (pos){
            if (pos == "left") {
                return{
                    "grid-column: 4 / 5"
                }
            }
            else{
                 return{
                    "grid-column: 1 / 2"
                }
            }
        }
    }
}

它似乎调用了该​​方法,但并没有改变我的 div 的样式。希望有人能帮忙:)谢谢你

解决方法

此外,您可以将其用作这样的属性值。 (我用颜色来形象化)

const {
  createApp
} = Vue

const App = {
  methods: {
    textposit(pos) {
      if (pos == "left") {
        return "red"
      } else {
        return "blue"
      }
    }
  }
}

Vue.createApp(App).mount('#app')
<script src="https://unpkg.com/vue@next"></script>

<div id="app">
  <div :style="{color: textposit('left')}">TEXT</div>
  <div :style="{color: textposit('somethingelse')}">TEXT</div>
</div>

,

您可以将其定义为计算属性而不是方法:

<div class="container"  :style=" textposit">

脚本:


export default {
    name: 'page',components: {
    },props:{
       //....
    },computed:{
      textposit (){
            if (this.textpos === "left") {
                return{
                    "grid-column": "4 / 5" 
                }
            }
            else{
                 return{
                    "grid-column": "1 / 2"
                }
            }
        }
    }
}

我还将 "grid-column: 4 / 5" 更改为 "grid-column": "4 / 5" 以使其成为有效的对象字段。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?