css - 如何在 vuetify 中堆叠复选框和图标

标签 css vue.js layout vuetify.js

我想要这样的东西(+是复选框,-是删除图标):

+ |‾‾‾‾‾‾|
- |______|

到目前为止,这是我尝试过的:

<!DOCTYPE html>
<html>

<head>
  <link href="https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900" rel="stylesheet">
  <link href="https://cdn.jsdelivr.net/npm/@mdi/font@3.x/css/materialdesignicons.min.css" rel="stylesheet">
  <link href="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.min.css" rel="stylesheet">
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no, minimal-ui">
</head>

<body>
  <div id="app">
    <v-app>
      <v-col cols="12" md="6" v-for="(choice, idx) in choices" :key="idx">
        <v-text-field v-model="choice.text" outlined clearable type="text">
          <template v-slot:prepend>
              <v-col>
                <v-checkbox v-model="choice.isCorrect" hide-details />
                <v-icon color="red" left>remove_circle</v-icon>
              </v-col>
            </template>
        </v-text-field>
      </v-col>
    </v-app>
  </div>

  <script src="https://cdn.jsdelivr.net/npm/vue@2.x/dist/vue.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.js"></script>
  <script>
    new Vue({
      el: '#app',
      vuetify: new Vuetify(),
      data() {
        return {
          choices: [{
              text: "Foo",
              isCorrect: true
            },
            {
              text: "Bar",
              isCorrect: false
            }
          ]
        }
      }
    })
  </script>
</body>

</html>

最佳答案

老实说,最好为此创建一个单独的 div,而不是使用前置插槽,它有一些奇怪的自定义边距,不太适合此目的。我已经编辑了您的代码以实现您想要的效果 - https://codepen.io/CodingDeer/pen/LYPbPxr .

我也将代码片段放在这里,但由于某种原因图标在这里不起作用。

<!DOCTYPE html>
<html>

<head>
  <link href="https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900" rel="stylesheet">
  <link href="https://cdn.jsdelivr.net/npm/@mdi/font@3.x/css/materialdesignicons.min.css" rel="stylesheet">
  <link href="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.min.css" rel="stylesheet">
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no, minimal-ui">
</head>

<body>
    <div id="app">
<v-app>
  <v-col cols="12" md="6" v-for="(choice, idx) in choices" :key="idx">
    <v-row>
      <div>
        <div>
          <v-checkbox 
            class="ma-0"
            v-model="choice.isCorrect" 
            hide-details />
        </div>
        <v-icon color="red">remove_circle</v-icon>
      </div>
      <v-text-field v-model="choice.text" outlined clearable type="text">
      </v-text-field>
    </v-row>
  </v-col>
</v-app>
  </div>

  <script src="https://cdn.jsdelivr.net/npm/vue@2.x/dist/vue.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.js"></script>
  <script>
    new Vue({
      el: '#app',
      vuetify: new Vuetify(),
      data() {
        return {
          choices: [{
              text: "Foo",
              isCorrect: true
            },
            {
              text: "Bar",
              isCorrect: false
            }
          ]
        }
      }
    })
  </script>
</body>

</html>

关于css - 如何在 vuetify 中堆叠复选框和图标,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57576884/

相关文章:

android - 引用另一个 layout.xml 文件而不复制它

javascript - jQuery 下拉菜单动画

html - 如何制作粘性页眉、页脚和侧边栏?

javascript - Vue.js - Prop 同步不是即时的

javascript - 使用 Vue.js 确定放置坐标是否位于另一个元素上方?

java - JScrollPane 内部的内部 JScrollPane 无法正常工作

python - addStretch 在 QBoxLayout 中究竟是如何工作的?

html - 调整浏览器窗口大小时,避免调整 block 级元素的大小

CSS 问题 - 背景颜色在 - Magento style.css 中没有响应

javascript - Nativescript 选项卡 View 更改不起作用