ホームページ > ウェブフロントエンド > jsチュートリアル > vue が提供するキープアライブによりサーバーへのリクエスト数を削減します。

vue が提供するキープアライブによりサーバーへのリクエスト数を削減します。

亚连
リリース: 2018-05-28 09:50:35
オリジナル
1102 人が閲覧しました

この記事ではサーバーへのリクエスト数を減らすためにvueが提供するキープアライブの使い方を中心に紹介していますので、vueルーティングでキープアライブを有効にする際の注意点も紹介していますので、必要な方は参考にしてください。

以下を見てください。 vue によって提供されるキープアライブは、サーバーへのリクエストの数を減らします。

VUE2.0 は、コンポーネントをキャッシュし、対応するコンポーネントの複数回のロードを回避し、リクエストの数を減らすために使用できるキープアライブ メソッドを提供します。パフォーマンスの消費。たとえば、画像やテキストなどを含むページのデータがユーザーによってロードされ、ユーザーはそれをクリックすることで別のインターフェイスにジャンプします。その後、別のインターフェースから元のインターフェースに戻ります。設定されていない場合は、再度元のインターフェースの情報をサーバーに要求します。 vue が提供するキープアライブは、ページの要求されたデータを保存し、要求の数を減らし、ユーザー エクスペリエンスを向上させることができます。キャッシュ コンポーネントは、サイト全体のページのコンポーネントとキャッシュのキャッシュ部分のコンポーネントの 2 種類に分けられます。

1. 各ページにリクエストがある状況に適した、すべてのページをキャッシュします。方法は以下の通り、キャッシュが必要なrouter-viewをkeep-aliveタグでラップします。 CACHEDを使用することは、作成されたフックに最初のトリガーリクエストを書き込むことで実現できます。たとえば、一覧ページから詳細ページに移動した場合、戻ってきたときに元のページが表示されます。

2. 一部のコンポーネントまたはページをキャッシュします。これは、router.meta 属性を使用して判断することで実現できます。方法は次のとおりです。 。名前には意味が含まれており、include は含めることを意味し、exclude は除外することを意味します。ここではコンポーネントの名前を使用して設定する必要があるため、名前を追加する必要があります。コンポーネント a と b を追加するにはキャッシュが必要ですが、コンポーネント c と d にはキャッシュが必要ありません。それは次のように書かれています:

 <keep-alive>
      <router-view></router-view>
     </keep-alive>
ログイン後にコピー

Vue プロジェクトの最適化は、画像の遅延読み込みと同様に、コンポーネントのオンデマンド読み込みによっても実現できます。顧客がそれらの画像をまったく表示しない場合でも、開くときにすべてを読み込みます。ページが完了すると、リクエスト時間が大幅に増加し、ユーザー エクスペリエンスが低下します。遅延読み込みは、淘宝網や JD.com などのショッピング サイトなど、多くの Web サイトで使用されており、スクロールをすばやく下に引くと、画像が読み込まれていることがわかります。

補足:

Vue ルーティングがキープアライブをオンにする場合の注意点

これはビジネス要件ではありませんが、ページに入るたびに DOM が再レンダリングされ、その後DOMを更新するためにデータを取得するのですが、フロントエンドエンジニアにとって読み込みロジックの最適化が必要だと思いますが、たまたまVueにキープアライブ機能があったので試してみました。もちろん、すべてが順風満帆というわけではなく、道での凹凸は避けられないので、ここで遭遇した問題を記録し、この記事を読んだ人が役立つことを願っています。 ps: これは難しいことではありません。 HTML 部分:

<keep-alive v-if="$route.meta.keepAlive">
      <router-view></router-view>
     </keep-alive>
     <router-view v-if="! $route.meta.keepAlive"></router-view>
ログイン後にコピー

...1. データを取得する段階

ページのライフサイクル フック 上記のコードに示されているように、これら 4 つは最も一般的に使用される部分です。この部分では、キープアライブを導入すると、最初にページに入ったときにフックのトリガーシーケンスが作成→マウント→アクティブ化され、終了時に非アクティブ化がトリガーされることに注意してください。再度入力した場合(前方または後方)、アクティブ化のみがトリガーされます。

キープアライブ後、ページテンプレートは初期化され、HTML フラグメントに初めて解析され、再度入力されると、再解析されず、メモリ内のデータが読み取られるだけであることがわかります。データが変更されると、差分更新に VirtualDOM が使用されます。したがって、ページに入るときに取得したデータもアクティブ化される必要があります。データをダウンロードした後、DOM の手動操作も実行して有効にする必要があります。

そのため、データ取得コードのコピーをアクティブ化したままにしておくか、作成された部分を省略して、作成されたコードをアクティブ化されたコードに直接転送する必要があります。

2. $route のデータを読み取ることができません

以前の記述方法は、他のメソッドの使用を容易にするために、データに必要な $route データを割り当てることでしたが、キープアライブを使用した後は、データを次のようにする必要があります。ページをアクティブ化して再度取得することによってのみ、更新の目的を達成できます。 initData メソッドを定義し、アクティブ化して開始します。

 routers:[
        { path: &#39;/home&#39;,
          name: home,
          meta:{keepAlive: true}  // 设置为true表示需要缓存,不设置或者false表示不需要缓存          }
          ]
ログイン後にコピー

3. 現在のページの URL を動的に変更します

需求描述:当页面在进行轮播操作的时候希望能记录当前显示的轮播ID(activeIndex)。当进入下一个页面再返回的时候能记住之前的选择,将轮播打到之前的ID位置。所以我想将这部分信息固化在url中,轮播发生变化时,修改URL。这样实现比较符最小修改原则,其余页面不用变动。

之前的写法是将activeIndex放在 $route 的query中,当轮播后,将

activeIndex的值存入 $route.query.activeIndex 中,然后 $router.replace 当前路由,理论上应该能发生变化,但实际没有。

查看文档后说, $route 是只读模式。当然,对象部分是他监管不到的,我修改了并不是正统的做法。

神奇的地方来了:当我将activeIndex记在params中,轮播变动修改params中的参数,然后 $router.replace 当前路由,却能发生对应的变化。代码如下:

let swiperInstance = new Swiper(&#39;#swiper&#39;, {
 pagination: &#39;.swiper-pagination&#39;,
 paginationClickable: false,
 initialSlide: activeIndex,
 onSlideChangeEnd: function (swiper) {
  let _activeIndex = swiper.activeIndex;
  _this.$route.params.activeIndex = _activeIndex;
  // $router我放到了window上方便调用
  window.$router.replace({
   name: _this.$route.name,
   params: _this.$route.params,
   query: _this.$route.query
  });
  // 根据activeIndex,在这里初始化下面显示的数据
  _this.transferDetail = _this.allData.plans[_activeIndex].segments;
  _this.clearBusDetailFoldState();
 }
});
ログイン後にコピー

4. 事件如何处理

估计你也能猜到,发生的问题是事件绑定了很多次,比如上传点击input监听change事件,突然显示了多张相同图片的问题。

也就是说,DOM在编译后就缓存在内容中了,如果再次进入还再进行事件绑定初始化则就会发生这个问题。

解决办法:在mounted中绑定事件,因为这个只执行一次,并且DOM已准备好。如果插件绑定后还要再执行一下事件的handler函数的话,那就提取出来,放在activated中执行。比如:根据输入内容自动增长textarea的高度,这部分需要监听textarea的input和change事件,并且页面进入后还要再次执行一次handler函数,更新textarea高度(避免上次输入的影响)。

5. 地图组件处理

想必这是使用 keep-alive 最直接的性能表现。之前是进入地图页面后进行地图渲染+线路标记;现在是清除以前的线路标记绘制新的线路,性能优化可想而知!

我这里使用的是高德地图,在mounted中初始化map,代码示例如下:

export default {
 name: &#39;transferMap&#39;,
 data: function () {
  return {
   map: null,
  }
 },
 methods: {
  initData: function () {},
  searchTransfer: function (type) {},
  // 地图渲染 这个在transfer-map.html中使用
  renderTransferMap: function (transferMap) {}
 },
 mounted: function () {
  this.map = new AMap.Map("container", {
   showBuildingBlock: true,
   animateEnable: true,
   resizeEnable: true,
   zoom: 12 //地图显示的缩放级别
  });
 },
 activated: function () {
  let _this = this;
  _this.initData();
  // 设置title
  setDocumentTitle(&#39;换乘地图&#39;);
  _this.searchTransfer(_this.policyType).then(function (result) {
   // 数据加载完成
   // 换乘地图页面
   let transferMap = result.plans[_this.activeIndex];
   transferMap.origin = result.origin;
   transferMap.destination = result.destination;
   // 填数据
   _this.transferMap = transferMap;
   // 地图渲染
   _this.renderTransferMap(transferMap);
  });
 },
 deactivated: function () {
  // 清理地图之前的标记
  this.map.clearMap();
 },
}
ログイン後にコピー

6. document.title修改

这个不是 keep-alive 的问题,不过我也在这里分享下。

问题是,使用下面这段方法,可以修改Title,但是页面来回切换多次后就不生效了,我也不知道为啥,放到setTimeout中就直接不执行。

document.title = '页面名称';下面是使用2种环境的修复方法:

纯js实现

function setDocumentTitle(title) {
 "use strict";
 //以下代码可以解决以上问题,不依赖jq
 setTimeout(function () {
  //利用iframe的onload事件刷新页面
  document.title = title;
  var iframe = document.createElement(&#39;iframe&#39;);
  iframe.src = &#39;/favicon.ico&#39;; // 必须
  iframe.style.visibility = &#39;hidden&#39;;
  iframe.style.width = &#39;1px&#39;;
  iframe.style.height = &#39;1px&#39;;
  iframe.onload = function () {
   setTimeout(function () {
    document.body.removeChild(iframe);
   }, 0);
  };
  document.body.appendChild(iframe);
 }, 0);
}
ログイン後にコピー

jQuery/Zepto实现

function setDocumentTitle(title) {
 //需要jQuery
 var $body = $(&#39;body&#39;);
 document.title = title;
 // hack在微信等webview中无法修改document.title的情况
 var $iframe = $(&#39;<iframe src="/favicon.ico"></iframe>&#39;);
 $iframe.on(&#39;load&#39;, function () {
  setTimeout(function () {
   $iframe.off(&#39;load&#39;).remove();
  }, 0);
 }).appendTo($body);
}
ログイン後にコピー

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

vue 指定组件缓存实例详解

使用JSON格式提交数据到服务端的实例代码

JavaScript动态加载重复绑定问题

以上がvue が提供するキープアライブによりサーバーへのリクエスト数を削減します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート