ホームページ  >  記事  >  ウェブフロントエンド  >  Jinri Toutiao モバイル端末のホームページ インターフェイスを模倣した JS

Jinri Toutiao モバイル端末のホームページ インターフェイスを模倣した JS

php中世界最好的语言
php中世界最好的语言オリジナル
2018-03-23 15:41:184680ブラウズ

今回はToutiaoモバイル端末のホームページインターフェースを模倣したJSの注意事項を紹介します。実際の事例を見てみましょう。

前書き

しばらくの間、Vue を使ってモバイル端末を書きたいと思っていましたが、年末であまり忙しくないので、それに取り組み始めました。数日前の時点ではほとんど読めません

私も純粋にフロントエンドページを書いているので、実際のリクエストをシミュレートするために、API を自分で直接生成できます。 Easy Mock で
このプロジェクトの Easy Mock アカウントとパスワードに直接ログインすることもできます:

アカウント: vue-toutiao
パスワード: 123456

インターフェースを変更したい場合は、コピーを作成して変更してくださいそれ

バックエンドインターフェイスを自分で開発したい場合。私のブログを読むことができます Vue + Node + Mongodb 完全なブログプロセスを開発します

テクノロジースタック:

vue + webpack + vuex + axios

構造:

  • ビルド: webpack 構成

  • config: プロジェクト設定パラメータ

  • src

  • assets: 画像を保存する静的リソースファイル

  • components: 一般的に使用されるコンポーネント。たとえば、ポップアップ ウィンドウなどです。 。 。

  • ディレクティブ: 共通コマンドのカプセル化

  • router: ルーティングテーブル

  • store: 状態管理vuex

  • styles: スタイルファイル

  • utils: 共通ユーティリティクラス

  • ビュー:ページを表示します

  • static: 静的ファイル: favicon.ico などを保存します

  • このプロジェクトはパッケージ化に DllPlugin を使用します。プロジェクトを開始するときに、必ずスクリプト コマンドを 1 回実行して構成を生成してください

。デモ:

いくつかの共通知識のポイント

1. ルートの遅延読み込み

{
  path: '/development',
  name: 'development',
  component: (resolve) => {
    require(['../views/development.vue'], resolve)
  }
}

または

const _import_ = file => () => import('views/' + file + '.vue')
{
  path: '/development',
  name: 'development',
  component: _import_('development')
}

2. ログインインターセプト

に合格しましたbeforeログインが必要かどうかを決定するためにルートの各フック関数が使用されます

// 如:系统设置需要登陆
{ 
  path: '/system', 
  name: '系统设置', 
  meta: { 
    login: true
  },
  component: _import_('System/index')
}
router.beforeEach((to, from, next) => {
  if (to.meta.login) { //判断前往的界面是否需要登陆
    if (store.state.user.user.name) { // 是否已经登陆
      next()
    }else{
      Vue.prototype.$alert('请先登录!')
        .then( () => {
          store.state.user.isLogin = true
        })
    }
  }else{
    if (to.meta.page) store.state.app.pageLoading = true
    next() 
  }
  
})

3. アニメーションの切り替え

ルーターに設定されているanimate属性を検出して、どのような種類の切り替えアニメーションを行うかを決定します

Router.prototype.animate = 0
// 获取每个路由meta上面的slide 来判断它做什么动画
{ 
  path: '/system', 
  name: '系统设置', 
  meta: { 
    slide: 1 
  },
  component: _import_('System/index')
}
watch: {
  $route (to, from) {
    /*
    0: 不做动画
    1: 左切换
    2: 右切换
    3: 上切换
    4: 下切换
    ...
     */
    let animate = this.$router.animate || to.meta.slide
    if (!animate) {
      this.animate = '' 
    }else{
      this.animate = animate === 1 ? 'slide-left' :
        animate === 2 ? 'slide-right' :
        animate === 3 ? 'slide-top' :
        animate === 4 ? 'slide-bottom' : ''
    }
    this.$router.animate = 0
  }
}

4.再生

IOS ではビデオ コントロールを非表示にできないため、キャンバスを描画することでビデオを非表示にし、ビデオを再生する効果を実現できます

この記事の事例を読んだ後、あなたはその方法をマスターしたと思います。さらに興味深い情報については、PHP 中国語 Web サイトの記事にあるその他の関連トピックにご注目ください。

推奨読書:

5 レベルの領域で click-to-load 読み込みを実装する

vue は自動 Web サイト構築プロジェクトを構築します

Vue.JS で echarts を使用する方法

以上がJinri Toutiao モバイル端末のホームページ インターフェイスを模倣した JSの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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