2

我正在玩VueVue Material组件,特别是Table 组件

我想做的是更改标题为表示例中的搜索图标/按钮的颜色,Within cards with Pagination and Inline Edit但似乎我必须遗漏一些东西,因为我无法让它从默认的灰色颜色改变,我是努力理解为什么会这样。

我有一个基本页面,其中包含 Vue 以及 Vue 材料所需的字体和图标以及它工作所需的 Javascript 和 CSS 文件。

索引.html

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Testing</title>
  <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700,400italic">
  <link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons">
  <link rel="stylesheet" href="https://cdn.rawgit.com/marcosmoura/vue-material/master/dist/vue-material.css" />
</head>
<body>
  <div id="app" v-md-theme="'default'">
    <md-table-card>
      <md-toolbar>
        <h1 class="md-title">Nutrition</h1>
        <md-button class="md-icon-button">
          <md-icon>filter_list</md-icon>
        </md-button>

        <md-button class="md-icon-button" @click="toggleSearch()">
          <md-icon v-if="searchEnabled" class="md-accent">search</md-icon>
          <md-icon v-else>search</md-icon>
        </md-button>
      </md-toolbar>

      <md-table md-sort="dessert" md-sort-type="desc" @select="onSelect" @sort="onSort">
        <md-table-header>
          <md-table-row>
            <md-table-head md-sort-by="dessert">Dessert (100g serving)</md-table-head>
            <md-table-head md-sort-by="calories" md-numeric md-tooltip="The total amount of food energy and the given serving size">Calories (g)</md-table-head>
            <md-table-head md-sort-by="fat" md-numeric>Fat (g)</md-table-head>
            <md-table-head md-sort-by="carbs" md-numeric>Carbs (g)</md-table-head>
            <md-table-head md-sort-by="protein" md-numeric>Protein (g)</md-table-head>
            <md-table-head>
              <md-icon>message</md-icon>
              <span>Comments</span>
            </md-table-head>
          </md-table-row>
        </md-table-header>

        <md-table-body>
          <md-table-row v-for="(row, rowIndex) in nutrition" :key="rowIndex" :md-item="row" md-auto-select md-selection>
            <md-table-cell v-for="(column, columnIndex) in row" :key="columnIndex" :md-numeric="columnIndex !== 'dessert' && columnIndex !== 'comment'" v-if="columnIndex !== 'type'">
              <md-table-edit
                :md-name="'comment' + columnIndex"
                :md-id="'comment' + columnIndex"
                md-placeholder="Add a comment"
                md-maxlength="120"
                v-model="nutrition[rowIndex].comment"
                v-if="columnIndex === 'comment'"></md-table-edit>

              <span v-if="columnIndex !== 'comment'"></span>
            </md-table-cell>
          </md-table-row>
        </md-table-body>
      </md-table>

      <md-table-pagination
        md-size="10"
        md-total="5"
        md-page="1"
        md-label="Rows"
        md-separator="of"
        :md-page-options="[5, 10, 25, 50]"
        @pagination="onPagination"></md-table-pagination>
    </md-table-card>
  </div>

  <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.1.3/vue.js" type="text/javascript"></script>
  <script src="https://cdn.rawgit.com/marcosmoura/vue-material/master/dist/vue-material.js" type="text/javascript"></script>
  <script src="app.js" type="text/javascript"></script>
</body>
</html>

应用程序.js

// Enable Vue Material
Vue.use(VueMaterial);

// Apply theme
Vue.material.theme.register('default', {
  primary: 'blue',
  accent: 'light-blue'
});

// Initialise Vue
new Vue({
  el: '#app',
  data: {
    nutrition: [{
      dessert: 'Frozen yogurt',
      type: 'ice_cream',
      calories: '159',
      fat: '6.0',
      carbs: '24',
      protein: '4.0',
      comment: 'Icy'
    }],
    selectedData: [],
    sort: {},
    page: {},
    searchEnabled: false
  },
  methods: {
    onSelect: function (data) {
      this.selectedData = data;
      this.$forceUpdate();
    },
    onSort: function (sort) {
      this.sort = sort;
    },
    onPagination: function (page) {
      this.page = page;
    },
    toggleSearch: function () {
      console.log(this.searchEnabled);
      if (this.searchEnabled) {
        this.searchEnabled = false;
      } else {
        this.searchEnabled = true;
      }
    }
  }
});

当我加载页面时,我会像示例一样获得带有表格的应用程序。当我单击搜索图标时,我可以从该方法中看到控制台日志,toggleSearch()并且它按预期在布尔值之间变化,但是,搜索图标的颜色没有改变。

查看搜索按钮的组件 HTML:

<md-button class="md-icon-button" @click="toggleSearch()">
  <md-icon v-if="searchEnabled" class="md-accent">search</md-icon>
  <md-icon v-else>search</md-icon>
</md-button>

我使用 if / else 条件在重音类和我假设的默认灰色之间切换,具体取决于布尔值searchEnabled,这适用于独立按钮,但不适用于表格内部。

任何人都可以提出一个为什么会发生这种情况的原因,或者我应该如何在表格中设置这个按钮的样式。任何输入或反馈将不胜感激,非常感谢!

(如果您可以建议 Vue 中是否有一种方法可以有条件地应用一个类,即代替使用v-ifv-else复制图标元素,那么我是否有另一种方法可以基于布尔值应用该类并只使用一个图标元素?)

4

2 回答 2

3

是的,您可以使用 VueJs 进行动态样式设置,是相同的文档。您可以将对象传递v-bind:class给动态切换类:

<md-button class="md-icon-button" @click="toggleSearch()">
  <md-icon v-bind:class="{ 'md-accent': searchEnabled }">search</md-icon>
</md-button>

上述语法意味着md-accent类的存在将由数据属性的真实性决定searchEnabled

于 2016-11-27T02:37:20.277 回答
1

这是在 v0.4.0 中修复的错误

于 2016-12-14T05:14:25.597 回答