目次
1. 実装のアイデア
2. 実装プロセス
1. 製品リスト データ ソースの定義
2. データ ソースに基づいて製品カードを生成します
3. 製品カードの幅と高さに応じて、位置ずれ後の位置を計算します
3. まとめ
ホームページ ウェブフロントエンド フロントエンドQ&A vueで商品リストのズレ配置機能を実装する方法

vueで商品リストのズレ配置機能を実装する方法

Apr 13, 2023 am 10:07 AM

近年、フロントエンド開発技術は急速に発展しており、Vue は近年最も人気のあるフロントエンド フレームワークの 1 つとして、多くの開発者に愛され、求められています。実際の開発プロセスでは、製品リストの表示やレンダリングに Vue が使用されることがよくあります。ただし、単純な商品リスト表示ではユーザーのニーズに応えることができないため、商品リストをずらして表示することで、ページの芸術性とユーザーエクスペリエンスを向上させることができます。 Vueで商品リストの千鳥配置を実現する方法を紹介します。

1. 実装のアイデア

製品リストの千鳥配置を実現するには、次の手順が必要です:

  1. 製品リスト データ ソースを定義します。
  2. データ ソースに基づいて製品カードを生成します;
  3. 製品カードの幅と高さに基づいて位置ずれ後の位置を計算します;
  4. 計算された位置を次を使用して各製品カードに適用しますCSS スタイル。

これらのステップの具体的な実装を個別に見てみましょう。

2. 実装プロセス

1. 製品リスト データ ソースの定義

まず、製品名、製品写真、製品価格、製品リスト データ ソースを準備する必要があります。その他の情報 。これらのデータは、JavaScript ファイルに保存できます (例:

const goods = [
  {
    id: 1,
    name: 'Apple iPhone 12',
    price: 6999,
    image: 'https://xxx.com/xxx.jpg'
  },
  {
    id: 2,
    name: 'Samsung Galaxy S21',
    price: 7999,
    image: 'https://xxx.com/xxx.jpg'
  },
  // ...
];
ログイン後にコピー

2. データ ソースに基づいて製品カードを生成します

Vue では、v-for 命令を使用して製品をレンダリングできます)カード。具体的な実装は次のとおりです:

<template>
  <div class="goods-list">
    <div
      class="goods-card"
      v-for="item in goods"
      :key="item.id"
    >
      <img :src="item.image" alt="商品图片" />
      <div class="info">
        <p class="name">{{ item.name }}</p>
        <p class="price">¥{{ item.price }}</p>
      </div>
    </div>
  </div>
</template>
ログイン後にコピー

3. 製品カードの幅と高さに応じて、位置ずれ後の位置を計算します

位置ずれの要件に従って、次のことが必要です。各製品カードの位置を計算します。商品カードの幅と高さ、コンテナの幅を取得することで、そのズレを計算できます。具体的な実装は次のとおりです。

computed: {
  // 计算出商品卡片的宽度
  cardWidth() {
    const containerWidth = /* 获取容器宽度 */;
    const gutter = /* 获取卡片之间的间距 */;
    const columnNum = /* 获取列数 */;

    return (containerWidth - gutter * (columnNum - 1)) / columnNum;
  },

  // 计算出商品卡片的高度
  cardHeight() {
    return /* 获取商品卡片的高度 */;
  },

  // 计算出每个商品卡片的错位位置
  positions() {
    const cardList = /* 获取商品卡片列表 */;
    const gutter = /* 获取卡片之间的间距 */;

    const positions = [];
    let x = 0;
    let y = 0;

    cardList.forEach((card, index) => {
      positions.push({ x, y });
      x += index % 2 === 0 ? this.cardWidth + gutter : -this.cardWidth - gutter;
      y += index % 2 === 0 ? 0 : this.cardHeight + gutter;
    });

    return positions;
  }
}
ログイン後にコピー

最後に、位置で計算された位置を各製品カードに適用できます。具体的な実装は以下の通りです:

<template>
  <div class="goods-list">
    <div
      class="goods-card"
      v-for="(item, index) in goods"
      :key="item.id"
      :style="{ left: positions[index].x + &#39;px&#39;, top: positions[index].y + &#39;px&#39; }"
    >
      <img :src="item.image" alt="商品图片" />
      <div class="info">
        <p class="name">{{ item.name }}</p>
        <p class="price">¥{{ item.price }}</p>
      </div>
    </div>
  </div>
</template>
ログイン後にコピー

3. まとめ

この記事では、Vueで商品リストの並びのずれを実現する方法を紹介します。上記の手順により、ユニークで美しい商品リストを簡単に実現でき、ユーザーエクスペリエンスが向上するだけでなく、ページの芸術性も向上します。この記事で説明されている内容をより深く理解するために、読み終わった後は手動で実装することをお勧めします。この記事があなたのお役に立てば幸いです。

以上がvueで商品リストのズレ配置機能を実装する方法の詳細内容です。詳細については、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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

HTMLにおけるReactの役割:ユーザーエクスペリエンスの向上 HTMLにおけるReactの役割:ユーザーエクスペリエンスの向上 Apr 09, 2025 am 12:11 AM

ReactはJSXとHTMLを組み合わせてユーザーエクスペリエンスを向上させます。 1)JSXはHTMLを埋め込み、開発をより直感的にします。 2)仮想DOMメカニズムは、パフォーマンスを最適化し、DOM操作を削減します。 3)保守性を向上させるコンポーネントベースの管理UI。 4)国家管理とイベント処理は、インタラクティブ性を高めます。

connect()を使用して、ReactコンポーネントをReduxストアにどのように接続しますか? connect()を使用して、ReactコンポーネントをReduxストアにどのように接続しますか? Mar 21, 2025 pm 06:23 PM

記事では、Connect()、MapStateToprops、MapDispatchToprops、およびパフォーマンスへの影響を説明するReduxストアに反応コンポーネントをReduxストアに接続します。

&lt; route&gt;を使用してルートをどのように定義しますか 成分? &lt; route&gt;を使用してルートをどのように定義しますか 成分? Mar 21, 2025 am 11:47 AM

この記事では、&lt; route&gt;を使用して、Reactルーターのルートの定義について説明します。パス、コンポーネント、レンダリング、子供、正確、ネストされたルーティングなどの小道具をカバーするコンポーネント。

Arrayおよびオブジェクトの変更に関するVUE 2の反応性システムの制限は何ですか? Arrayおよびオブジェクトの変更に関するVUE 2の反応性システムの制限は何ですか? Mar 25, 2025 pm 02:07 PM

VUE 2の反応性システムは、直接配列インデックス設定、長さの変更、およびオブジェクトプロパティの追加/削除と闘っています。開発者は、Vueの突然変異法とVue.set()を使用して、反応性を確保することができます。

Redux Reducersとは何ですか?彼らはどのように州を更新しますか? Redux Reducersとは何ですか?彼らはどのように州を更新しますか? Mar 21, 2025 pm 06:21 PM

Redux Reducersは、アクションに基づいてアプリケーションの状態を更新する純粋な機能であり、予測可能性と不変性を確保します。

Reduxアクションとは何ですか?どのように派遣しますか? Reduxアクションとは何ですか?どのように派遣しますか? Mar 21, 2025 pm 06:21 PM

この記事では、Redux Thunkを使用した非同期アクションを含む、Reduxアクション、その構造、および派遣方法について説明します。スケーラブルで保守可能なアプリケーションを維持するために、アクションタイプを管理するためのベストプラクティスを強調しています。

TypeScriptをReactで使用することの利点は何ですか? TypeScriptをReactで使用することの利点は何ですか? Mar 27, 2025 pm 05:43 PM

タイプスクリプトは、タイプの安全性を提供し、コードの品質を改善し、IDEサポートを改善し、エラーを減らし、保守性を向上させることにより、反応開発を促進します。

反応コンポーネント:HTMLで再利用可能な要素を作成します 反応コンポーネント:HTMLで再利用可能な要素を作成します Apr 08, 2025 pm 05:53 PM

Reactコンポーネントは、機能またはクラスによって定義され、UIロジックのカプセル化、およびプロップを介して入力データを受け入れることができます。 1)コンポーネントの定義:関数またはクラスを使用して、反応要素を返します。 2)レンダリングコンポーネント:Reactコールレンダリングメソッドまたは機能コンポーネントを実行します。 3)マルチプレックスコンポーネント:データをプロップに渡して、複雑なUIを構築します。コンポーネントのライフサイクルアプローチにより、ロジックをさまざまな段階で実行でき、開発効率とコードメンテナビリティが向上します。

See all articles