vueのワンクリック削除機能

王林
リリース: 2023-05-11 13:54:37
オリジナル
922 人が閲覧しました

多くの Web アプリケーションでは、削除機能は、ユーザーが不要になった特定のデータ レコードを簡単に削除できるようにする基本操作です。 Vue では、いくつかの組み込み命令とメソッドを使用して、ワンクリック削除機能を実装できます。この記事では、Vueにワンクリック削除機能を実装する方法を紹介します。

  1. 削除するデータを決定する

始める前に、どのデータを削除するかを明確にする必要があります。通常、バックエンドにリクエストを送信することで、削除するデータを取得できます。この記事では、この機能をシミュレートするため、これを行うためにシミュレートされたデータを使用します。

削除したいデータを含むテーブルを含む Delete List というコンポーネントがあるとします。物事を簡単にするために、例として次のシミュレートされたデータを使用します。

data() {
  return {
    items: [
      { id: 1, name: '物品1', description: '这是一件好物品' },
      { id: 2, name: '物品2', description: '这是另一件好物品' },
      { id: 3, name: '物品3', description: '这也是一件好物品' }
    ],
    selectedItems: []
  };
}
ログイン後にコピー

ここで、items はすべてのデータ レコードを含む配列であり、selectedItems は空の配列です。には、削除するデータが含まれます。

  1. チェック ボックスの作成

ワンクリック削除機能を実装するには、ユーザーが複数のデータ レコードを選択できるようにする必要があります。これを行うには、各データ レコードにチェックボックスを追加する必要があります。 Vue の v-for ディレクティブを使用して、各データ レコードを反復処理し、各チェックボックスを selectedItems という配列にバインドできます。

<table>
  <thead>
    <tr>
      <th>选择</th>
      <th>名称</th>
      <th>描述</th>
    </tr>
  </thead>
  <tbody>
    <tr v-for="item in items" :key="item.id">
      <td><input type="checkbox" :value="item" v-model="selectedItems"></td>
      <td>{{item.name}}</td>
      <td>{{item.description}}</td>
    </tr>
  </tbody>
</table>
ログイン後にコピー

各チェック ボックスの値をバインドするために v-model ディレクティブを使用していることに注意してください。各チェックボックスの値は、そのデータ レコードを含む item オブジェクトになります。

  1. 選択した項目の削除

ユーザーが削除するデータ レコードを選択したら、ボタンを使用して削除操作を実行する必要があります。組み込みの splice メソッドを使用して、選択されたデータ レコードを配列から削除するメソッドを Vue コンポーネントに定義します。

methods: {
  deleteSelectedItems() {
    this.selectedItems.forEach(item => {
      const index = this.items.indexOf(item);
      this.items.splice(index, 1);
    });
    this.selectedItems = [];
  } 
}
ログイン後にコピー

ここでは、まず選択したデータ レコードを反復処理し、items 配列内の各データ レコードのインデックスを見つけて、splice メソッドを使用して削除します。次に、選択したデータ レコードを selectedItems 配列でリセットします。

  1. 削除ボタンをメソッドにバインドする

選択した項目を削除するメソッドができたので、ユーザーがクリックして削除できるボタンを作成する必要があります。選択されたデータレコード。

<button @click="deleteSelectedItems" :disabled="selectedItems.length === 0">删除所选项</button>
ログイン後にコピー

ここで、@click ディレクティブは deleteSelectedItems メソッドをバインドし、disabled は選択されたデータ レコードが存在しない場合にのみ発生する条件をバインドします。ボタンは空の場合にのみクリックできます。

  1. 完全なコード

これで、Vue でのワンクリック削除機能の実装が完了しました。完全なコードは次のとおりです:



<script>
export default {
  data() {
    return {
      items: [
        { id: 1, name: '物品1', description: '这是一件好物品' },
        { id: 2, name: '物品2', description: '这是另一件好物品' },
        { id: 3, name: '物品3', description: '这也是一件好物品' }
      ],
      selectedItems: []
    };
  },
  methods: {
    deleteSelectedItems() {
      this.selectedItems.forEach(item => {
        const index = this.items.indexOf(item);
        this.items.splice(index, 1);
      });
      this.selectedItems = [];
    } 
  }
};
</script>
ログイン後にコピー
  1. 結論

Vue でワンクリック削除機能を実装するのは非常に簡単です。 Vue のテンプレート構文とカスタム メソッドを使用してチェックボックスを作成し、データ レコードが選択されたらボタンでチェックボックスを削除できます。これは、Vue で削除を処理するための基本的なテクニックの 1 つであり、バックエンド API と組み合わせて使用​​すると、より複雑な機能を実現できます。

以上がvueのワンクリック削除機能の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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