ホームページ  >  記事  >  ウェブフロントエンド  >  vueでスタイルを切り替える方法

vueでスタイルを切り替える方法

亚连
亚连オリジナル
2018-06-19 16:48:362190ブラウズ

この記事では、Vue でスタイルを切り替える方法と、Vue で動的スタイルを実装する方法を主に紹介します。必要な友達は参考にしてください。 vueを選択しました。作るときにdomの操作を考えず、すべてvueに任せます。

以下は非常にシンプルですが非常に一般的なエフェクトです。おそらく誰もがそのようなニーズを使用するでしょう下の図を参照してください

ナビゲーションバーのスタイル切り替え機能をjqueryのようなものを使用して書くと、多くのコードを記述する必要がある場合があるため、vue を使用します

コードは次のとおりです

html

vue のスタイルとクラス バインディング API を添付します

<p id="wrap" class="box">
  <p v-for="(list,index) in navLists" class="nav" :class="{ red:changeRed == index}" @click="reds(index)">{{list.text}}</p>
</p>

css

 *{
        padding: 0;margin: 0;
      }
      .box{
        height: 40px;
        background: cyan;
      }
      .nav{
        line-height: 40px;
        display: inline-block;
        margin-left: 100px;
        cursor: pointer;
      }
      .red{
        color: red;
      }

//前提是必须引入vuejs哦!
var vm = new Vue({
      el:"#wrap",
      data:{
        navLists:[
          {
            "text":"首页"           
          },
          {
            "text":"组件"           
          },
          {
            "text":"API"            
          },
          {
            "text":"我们"           
          }
        ],
        changeRed:0
      },
      methods:{
        reds:function(index){
          this.changeRed = index;
        }
      }
    });
よく見てください JS コードを見ると、シミュレートされたデータに加えて、実際には単純な論理処理だけがあり、これまでのさまざまな dom 操作に比べて大幅に手間が省かれています。

ps: vueの動的スタイルの解決策

:class="{active: isActive}"

これについては言うことはありませんが、クラス名に「-」記号が含まれている場合はエラーが報告されます

別の

class="[lineStyle(courseClick)]"
    lineStyle(isClick){
        if (isClick===true){
          return &#39;tab-items-current&#39;
        }else {
          return &#39;class-tab-items&#39;
        }
      }
は上記です。私がまとめたものは、今後も皆様のお役に立てば幸いです。 関連記事:

JavaScriptで自動数値インクリメントを実装する方法

ReactプロジェクトでReduxを使用する方法(詳細なチュートリアル)

ionic3でランダムレイアウトのウォーターフォールフローを実装する方法

JSでトップに戻る効果を達成する方法

以上がvueでスタイルを切り替える方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。