目次
1.vue-cli
2.vue-router
3. コンポーネントでのコンポーネントの使用
4.vue-resource
5.vuex
ホームページ ウェブフロントエンド jsチュートリアル vue2 ファミリーバケットとは何ですか?またその使用方法は何ですか?

vue2 ファミリーバケットとは何ですか?またその使用方法は何ですか?

Mar 16, 2018 am 11:05 AM
vue2 使用 とは

今回は、vue2ファミリーバケットとは何か、そしてその使い方について説明します。 , vue2ファミリーバケットとは何ですか?使用する際の注意事項は何ですか? 以下は実際のケースですので、一緒に見てみましょう。

Vue2 はシンプルで始めやすいと言われていますが、実際に試してみるとわかります。ES6 の構文や Webpack の構成に加えて、重要なのは考え方の変更です。以前は、グローバル変数を使用して DOM を変更することができましたが、ハンマーは使用できなくなったので、データ自体に注目してください。 vue の公式ドキュメントは浅いものから深いものまで非常に充実していますが、vue-cli を使用してプロジェクトを構築する場合、公式ドキュメントではまだ不十分であることがわかり、git 上のオープンソース プロジェクトを参照して学習する必要があります。エス6。また、vue のファミリー バケット (vue-cli、vue-router、vue-resource、vuex) もインストールする必要があります。

1.vue-cli

このビルド ツールは、webpack の使用の難しさを大幅に軽減し、ホット アップデートをサポートし、webpack-dev-server のサポートを備えています。これは、リクエスト サーバーの起動とテスト環境のセットアップに相当します。あなたは開発だけに集中してください。

# 全局安装 vue-cli
$ npm install --global vue-cli
# 创建一个基于 webpack 模板的新项目
$ vue init webpack my-project
# 安装依赖,走你
$ cd my-project
$ npm install
$ npm run dev
ログイン後にコピー

ホット アップデートのメカニズムは、ファイルの変更を検出し、WebSocket を使用してクライアントに対応する更新を行うように通知することです。詳細については、[webpack]--module hot replace

2.vue-router

vue のルーティングは依然として非常に便利で、ag1 よりもはるかに便利です。この便利さは 3 つの側面に反映されています:

1 はルーティングとページ (コンポーネント) の対応です:

import Vue from 'vue'import Router from 'vue-router'import Home from '@/components/Home'import Chat from '@/components/Chat'import Firends from '@/components/Firends'import Logon from '@/components/Logon'Vue.use(Router)
let router=new Router({
  routes: [
    {
      path: '/home',
      name: 'Home',
      component: Home
    },
     { path: '/', redirect: '/home' },//重定向
    {
      path: '/chat',
      name: 'Chat',
      component: Chat
    },
    {
      path: '/firends',
      name: 'Firends',
      component: Firends
    },
    {
      path: '/logon',
      name: 'Logon',
      component: Logon
    }
  ]
});
ログイン後にコピー

普通の人の考え方は次のとおりで、ag1 も コントローラー を持ってくる必要があります (vue にはそのような概念はありません)代わりに、コンポーネントに注目するだけです)。これにより、使いやすくなります。 MVC モードでは、コントローラーの下のアクションをポイントする必要があります。ナビゲーション カテゴリが多数ある場合、対応する戦略はネストされたルーティングです。

2 は要素に固有にすることができます:

<router-link    class="footer-item"  exact  to="home">首页</router-link>
ログイン後にコピー

この to の後のホーム (大文字と小文字を無視) は、上で定義したルート名です。これはとても便利です。 Asp.net MVC と同様のルーティングでは、常にパスを入力しなくても、名前でパスをレンダリングできます。

3 つはイベント インターセプトです:

検証したい場合、最善の方法は、ユーザーがページに到達する前に検証することです:

router.beforeEach((to, from, next) => {  //todo 以后增加不需要验证的地址判断
  if(to.path!=="/logon"&&!store.state.userInfo.Account){
     next({ path: '/logon' })     return;
  }else{
   next();
  } 
})
ログイン後にコピー

たとえば、beforeEach で処理します。また、多くの機能があるため、すべてをリストすることはしません。公式ドキュメント: http://router.vuejs.org/zh-cn/

3. コンポーネントでのコンポーネントの使用

いくつかのモバイル UI ライブラリを調べました。最初はなぜフッター コンポーネントがないのか疑問に思っていましたが、今ではルーティングが非常に便利であるため、サードパーティの UI がフッターをカプセル化する必要がなく、カプセル化するのが不便であることがわかりました。ルーティングに依存します)。したがって、ナビゲーションはおそらく自分で作成する必要がある最初のコンポーネントです。

たとえば、Footer.vue

    
     
     
     
     首页
     
     
      
      
      统计
     
       
      
      
      更多
ログイン後にコピー

<script><br> デフォルトのエクスポート {<br> name: 'VFooter'<br>}<br></script>

を定義する場合、アプリに

import VFooter from './VFooter'
 export default {
name: 'app',
data () {return {
msg: 'this is home'}
},components:{VFooter}}
ログイン後にコピー

を導入するだけで済みます。 Vue を使って App.Vue で使用できます

<VFooter></VFooter>
ログイン後にコピー

グローバルに登録したい場合は、まず main.js に導入するだけです

import Footer from './components/VFooter'//Vue.component('VFooter', Footer)//写在构造函数之前
ログイン後にコピー

このステップで、楽しく独自のページを組み立てることができます。ページにスライド効果を追加する必要がある場合は、トランジション (app.vue にあります) を追加できます:

  <transition  name="slide-in" mode="out-in">
    <router-view></router-view>
   </transition>
ログイン後にコピー
.slide-out-enter-active,
.slide-out-leave-active,
.slide-in-enter-active,
.slide-in-leave-active {
  will-change: transform;
  transition: all 400ms;
  position: absolute;
}.slide-out-enter {
  opacity: 0;
   transform: translateX(-100%);
  
}.slide-out-leave-active {
  opacity: 0;
   transform: translateX(100%);
  
}.slide-in-enter {
  opacity: 0;
   transform: translateX(100%);
}.slide-in-leave-active {
  opacity: 0;
   transform: translateX(-100%);
ログイン後にコピー

左右を切り替えるには?

4.vue-resource

ページが完了したら、リクエストを送信できる必要があります。 https://github.com/pagekit/vue-resource フロントエンドが独自にインターフェイスを作成しない場合、最初に注意すべきことは、プロキシを設定する方法です。これは、config の下の proxyTable にあります。 /index.js.

    proxyTable: {    '/api':
     {
           target: 'http://11.111.249.12:11',           changeOrigin: true,
           pathRewrite:
           {              '^/api': ''
            }
    },
ログイン後にコピー

クロスドメイン設定は、changeOrigin なしでは行えません。最後の '^/api': '' にも注意してください。 選択した「/api」が元のパスの一部であるかどうかに注意してください。そうでない場合は、間違いが発生しやすくなります。

次に、リクエスト ヘッダー (main.js) を設定する別の部分があります:

import VueResource from 'vue-resource'Vue.use(VueResource);
Vue.http.interceptors.push(function(request, next) {// modify method
  //request.method = 'POST';
  // modify headers      
  request.headers.set('token',“token”);// continue to next interceptor  next();
});
ログイン後にコピー

5.vuex

Family Bucket の最初に私を最も混乱させたのは、この vuex でした。これは一体何ですか、なぜこれが必要ですか。私は React をプレイしたことがなく、状態管理が何なのか知りません。グローバル変数を使用したい場合、これまでの方法はすべて機能しないことがわかります。たとえば、ログイン ステータス

let login=(name,pwd,success,fail)=>}).then(res=>
ログイン後にコピー

を設定し、それをホームページに表示します:

<p @click="toggle">{{hasLogin}}</p>
ログイン後にコピー
data () {    return {
      hasLogin:window.hasLogin
    }
  },
   methods:{
     toggle(){
       window.hasLogin=!window.hasLogin;
       console.log("clicked",window.hasLogin)
     }
   },
ログイン後にコピー

ログインすると確かに true が表示されますが、どのクリックしても false または true に切り替わりません。

需要再赋值一次:

this.hasLogin=window.hasLogin;
ログイン後にコピー

为什么呢?因为你自己定义的变量,根本不属于vue的model。也就是没有处理过geter和seter,虽然变量的值是变化了,但仍然无法改变界面上的状态。所以你需要一个状态管理,按照一定的机制把你的变量变换成vue内部的模型。这个东西就是vuex。因为约定比较多,略显复杂点,但是耐心看一下还是很容易接受的。它主要分四个部分,state,getters,mutations,actions。先定义一个user.js如下:

state就是我们放共享变量的地方。比如下面的userInfo.

import Vue from 'vue';
import Vuex from 'vuex';
Vue.use(Vuex);
const userStore=new Vuex.Store({
   state:{
       userInfo:{
           userName:""
       }
   },
   getters:{
       getUserInfo(state){           return state.userInfo;
       }
   },
   mutations:{
       setUserInfo(state,userInfo){
           state.userInfo=userInfo;
       }
   },
   actions:{
       setUserInfo({commit}){
           commit('setUserInfo');
       }
   }
})
export default userStore;
ログイン後にコピー

而getters顾名思义就是获取接口,mutations(突变)这个词有点唬人,其实就是setters嘛。里面的方法自带state参数。而actions就是mutations的异步方法。然后再main.js中引用一下:

import store from './store/user';//...
 new Vue({
  el: '#app',
  router,  store,
  template: '<App/>',
  components: { App }
})
ログイン後にコピー

然后我们在设置或获取的时候就可以使用指定的方法:

import store from '@/store/user';
//...
store.commit('setUserInfo',user)
ログイン後にコピー

 可以直接通过store.state获取变量,也可以通过getters接口:

 computed:{   ...mapGetters({username:'getUserName'})
  },
ログイン後にコピー

这三个点是es6中的扩展运算符。将一个数组转为用逗号分隔的参数序列。

当然这些状态刷新之后就没有了,如果想要暂存下来,可以放到sessionStorage中:

if (window.sessionStorage.user) {    var json=JSON.parse(window.sessionStorage.user);
    store.commit('setSessionUser',json)}
ログイン後にコピー

当然要在muations中放进去

  ==
ログイン後にコピー

官方文档: https://vuex.vuejs.org/zh-cn/

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

vue的自定义动态组件使用详解

protobuf.js 与 Long.js的使用详解

让JS自动匹配出proto Js的方法

以上がvue2 ファミリーバケットとは何ですか?またその使用方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

マグネットリンクの使い方 マグネットリンクの使い方 Feb 18, 2024 am 10:02 AM

マグネット リンクは、リソースをダウンロードするためのリンク方法であり、従来のダウンロード方法よりも便利で効率的です。マグネット リンクを使用すると、中間サーバーに依存せずに、ピアツーピア方式でリソースをダウンロードできます。この記事ではマグネットリンクの使い方と注意点を紹介します。 1. マグネット リンクとは? マグネット リンクは、P2P (Peer-to-Peer) プロトコルに基づくダウンロード方式です。ユーザーはマグネット リンクを通じてリソースの発行者に直接接続し、リソースの共有とダウンロードを完了できます。従来のダウンロード方法と比較して、磁気

ccsvchst.exe はどのようなプロセスですか? ccsvchst.exe はどのようなプロセスですか? Feb 19, 2024 pm 11:33 PM

ccsvchst.exe は、Symantec Endpoint Protection (SEP) ソフトウェアの一部である共通プロセス ファイルです。SEP は、有名なネットワーク セキュリティ会社 Symantec によって開発されたエンドポイント保護ソリューションです。ソフトウェアの一部として、ccsvchst.exe は SEP 関連のプロセスの管理と監視を担当します。まず、SymantecEndpointProtection(

mdfおよびmdsファイルの使用方法 mdfおよびmdsファイルの使用方法 Feb 19, 2024 pm 05:36 PM

mdf ファイルと mds ファイルの使用方法 コンピューター技術の継続的な進歩により、さまざまな方法でデータを保存および共有できるようになりました。デジタル メディアの分野では、特殊なファイル形式に遭遇することがよくあります。この記事では、一般的なファイル形式である mdf および mds ファイルについて説明し、その使用方法を紹介します。まず、mdf ファイルと mds ファイルの意味を理解する必要があります。 mdf は CD/DVD イメージ ファイルの拡張子で、mds ファイルは mdf ファイルのメタデータ ファイルです。

CrystalDiskmarkとはどのようなソフトウェアですか? -crystaldiskmarkの使い方は? CrystalDiskmarkとはどのようなソフトウェアですか? -crystaldiskmarkの使い方は? Mar 18, 2024 pm 02:58 PM

CrystalDiskMark は、シーケンシャルおよびランダムの読み取り/書き込み速度を迅速に測定する、ハード ドライブ用の小型 HDD ベンチマーク ツールです。次に、編集者が CrystalDiskMark と Crystaldiskmark の使用方法を紹介します。 1. CrystalDiskMark の概要 CrystalDiskMark は、機械式ハード ドライブとソリッド ステート ドライブ (SSD) の読み取りおよび書き込み速度とパフォーマンスを評価するために広く使用されているディスク パフォーマンス テスト ツールです。 ). ランダム I/O パフォーマンス。これは無料の Windows アプリケーションで、使いやすいインターフェイスとハード ドライブのパフォーマンスのさまざまな側面を評価するためのさまざまなテスト モードを提供し、ハードウェアのレビューで広く使用されています。

foob​​ar2000のダウンロード方法は? -foobar2000の使い方 foob​​ar2000のダウンロード方法は? -foobar2000の使い方 Mar 18, 2024 am 10:58 AM

foob​​ar2000 は、音楽リソースをいつでも聴くことができるソフトウェアです。あらゆる種類の音楽をロスレス音質で提供します。音楽プレーヤーの強化版により、より包括的で快適な音楽体験を得ることができます。その設計コンセプトは、高度なオーディオをコンピュータ上で再生可能 デバイスを携帯電話に移植し、より便利で効率的な音楽再生体験を提供 シンプルでわかりやすく、使いやすいインターフェースデザイン 過度な装飾や煩雑な操作を排除したミニマルなデザインスタイルを採用また、さまざまなスキンとテーマをサポートし、自分の好みに合わせて設定をカスタマイズし、複数のオーディオ形式の再生をサポートする専用の音楽プレーヤーを作成します。過度の音量による聴覚障害を避けるために、自分の聴覚の状態に合わせて調整してください。次は私がお手伝いさせてください

Baidu Netdisk アプリの使用方法 Baidu Netdisk アプリの使用方法 Mar 27, 2024 pm 06:46 PM

クラウド ストレージは今日、私たちの日常生活や仕事に欠かせない部分になっています。中国有数のクラウド ストレージ サービスの 1 つである Baidu Netdisk は、強力なストレージ機能、効率的な伝送速度、便利な操作体験により多くのユーザーの支持を得ています。また、重要なファイルのバックアップ、情報の共有、オンラインでのビデオの視聴、または音楽の聴きたい場合でも、Baidu Cloud Disk はニーズを満たすことができます。しかし、Baidu Netdisk アプリの具体的な使用方法を理解していないユーザーも多いため、このチュートリアルでは Baidu Netdisk アプリの使用方法を詳しく紹介します。まだ混乱しているユーザーは、この記事に従って詳細を学ぶことができます。 Baidu Cloud Network Disk の使用方法: 1. インストール まず、Baidu Cloud ソフトウェアをダウンロードしてインストールするときに、カスタム インストール オプションを選択してください。

NetEase メールボックス マスターの使用方法 NetEase メールボックス マスターの使用方法 Mar 27, 2024 pm 05:32 PM

NetEase Mailbox は、中国のネットユーザーに広く使用されている電子メール アドレスとして、その安定した効率的なサービスで常にユーザーの信頼を獲得してきました。 NetEase Mailbox Master は、携帯電話ユーザー向けに特別に作成された電子メール ソフトウェアで、電子メールの送受信プロセスが大幅に簡素化され、電子メールの処理がより便利になります。 NetEase Mailbox Master の使い方と具体的な機能について、以下ではこのサイトの編集者が詳しく紹介しますので、お役に立てれば幸いです。まず、モバイル アプリ ストアで NetEase Mailbox Master アプリを検索してダウンロードします。 App Store または Baidu Mobile Assistant で「Ne​​tEase Mailbox Master」を検索し、画面の指示に従ってインストールします。ダウンロードとインストールが完了したら、NetEase の電子メール アカウントを開いてログインします。ログイン インターフェイスは次のとおりです。

BTCC チュートリアル: BTCC 取引所で MetaMask ウォレットをバインドして使用する方法は? BTCC チュートリアル: BTCC 取引所で MetaMask ウォレットをバインドして使用する方法は? Apr 26, 2024 am 09:40 AM

MetaMask (中国語ではリトル フォックス ウォレットとも呼ばれます) は、無料で評判の高い暗号化ウォレット ソフトウェアです。現在、BTCC は MetaMask ウォレットへのバインドをサポートしており、バインド後は MetaMask ウォレットを使用してすぐにログイン、値の保存、コインの購入などが可能になり、初回バインドで 20 USDT のトライアル ボーナスも獲得できます。 BTCCMetaMask ウォレットのチュートリアルでは、MetaMask の登録方法と使用方法、および BTCC で Little Fox ウォレットをバインドして使用する方法を詳しく紹介します。メタマスクウォレットとは何ですか? 3,000 万人を超えるユーザーを抱える MetaMask Little Fox ウォレットは、現在最も人気のある暗号通貨ウォレットの 1 つです。無料で使用でき、拡張機能としてネットワーク上にインストールできます。

See all articles