7.8 KiB
メッセージ
アクティビティ後のフィードバックを表示するために使用されます。Notificationとの違いは、後者はシステムレベルの受動的な通知を表示するために使用されることが多いことです。
基本的な使い方
上部に表示され、3秒後に消えます。
:::demo メッセージの設定は通知と非常に似ているので、ここではオプションの詳細については説明しません。以下のオプション表とnotificationのドキュメントを組み合わせて確認すると理解が深まります。要素には $message
メソッドを登録しています。メッセージは文字列かVNodeをパラメータに取ることができ、それが本文として表示されます。
<template>
<el-button :plain="true" @click="open">Show message</el-button>
<el-button :plain="true" @click="openVn">VNode</el-button>
</template>
<script>
export default {
methods: {
open() {
this.$message('This is a message.');
},
openVn() {
const h = this.$createElement;
this.$message({
message: h('p', null, [
h('span', null, 'Message can be '),
h('i', { style: 'color: teal' }, 'VNode')
])
});
}
}
}
</script>
:::
タイプ
成功、警告、メッセージ、エラーのアクティビティのフィードバックを表示するために使用されます。
:::demo さらにカスタマイズが必要な場合は、メッセージコンポーネントはオブジェクトをパラメータとして受け取ることもできます。例えば、type
の値を設定することで異なるタイプを定義することができ、デフォルトは info
です。このような場合、message
の値として本体が渡されます。また、型ごとにメソッドを登録しているので、open4
のように型を渡さずに直接呼び出すこともできる。
<template>
<el-button :plain="true" @click="open2">success</el-button>
<el-button :plain="true" @click="open3">warning</el-button>
<el-button :plain="true" @click="open1">message</el-button>
<el-button :plain="true" @click="open4">error</el-button>
</template>
<script>
export default {
methods: {
open1() {
this.$message('This is a message.');
},
open2() {
this.$message({
message: 'Congrats, this is a success message.',
type: 'success'
});
},
open3() {
this.$message({
message: 'Warning, this is a warning message.',
type: 'warning'
});
},
open4() {
this.$message.error('Oops, this is a error message.');
}
}
}
</script>
:::
クローズ可能
閉じるボタンを追加することができます。
:::demo デフォルトのメッセージは手動で閉じることができません。メッセージを閉じたい場合は showClose
フィールドを設定することができます。通知と同様に、メッセージにも制御可能な duration
があります。デフォルトの持続時間は3000msで、0
に設定してもメッセージは消えません。
<template>
<el-button :plain="true" @click="open1">message</el-button>
<el-button :plain="true" @click="open2">success</el-button>
<el-button :plain="true" @click="open3">warning</el-button>
<el-button :plain="true" @click="open4">error</el-button>
</template>
<script>
export default {
methods: {
open1() {
this.$message({
showClose: true,
message: 'This is a message.'
});
},
open2() {
this.$message({
showClose: true,
message: 'Congrats, this is a success message.',
type: 'success'
});
},
open3() {
this.$message({
showClose: true,
message: 'Warning, this is a warning message.',
type: 'warning'
});
},
open4() {
this.$message({
showClose: true,
message: 'Oops, this is a error message.',
type: 'error'
});
}
}
}
</script>
:::
中央のテキスト
テキストを中央に配置するには center
属性を使用します。
:::demo
<template>
<el-button :plain="true" @click="openCenter">Centered text</el-button>
</template>
<script>
export default {
methods: {
openCenter() {
this.$message({
message: 'Centered text',
center: true
});
}
}
}
</script>
:::
HTML文字列を使用します。
message
は HTML 文字列をサポートしています。
:::demo dangerouslyUseHTMLString
を true に設定すると、message
は HTML 文字列として扱われます。
<template>
<el-button :plain="true" @click="openHTML">Use HTML String</el-button>
</template>
<script>
export default {
methods: {
openHTML() {
this.$message({
dangerouslyUseHTMLString: true,
message: '<strong>This is <i>HTML</i> string</strong>'
});
}
}
}
</script>
:::
:::warning
message
プロパティはHTML文字列をサポートしていますが、任意のHTMLを動的にレンダリングするとXSS攻撃につながりやすく、非常に危険です。したがって、dangerouslyUseHTMLString
がオンの場合は、message
の内容が信頼できるものであることを確認し、決してユーザが提供したコンテンツにmessage
を代入しないようにしてください。
:::
グローバルメソッド
要素には、Vue.prototype用のグローバルメソッド $message
が追加されました。これにより、vueのインスタンスでは、このページで行ったように Message
を呼び出すことができます。
ローカルインポート
Import Message
:
import { Message } from 'element-plus';
この場合は Message(options)
を呼び出す必要があります。また、Message.success(options)
のように、異なるタイプのメソッドも登録しています。すべてのインスタンスを手動で閉じるには、Message.closeAll()
を呼び出すことができます。
オプション
Attribute | Description | Type | Accepted Values | Default |
---|---|---|---|---|
message | メッセージテキスト | string / VNode | — | — |
type | メッセージタイプ | string | success/warning/info/error | info |
iconClass | カスタムアイコンのクラス、 type をオーバーライドします。 |
string | — | — |
dangerouslyUseHTMLString | message を HTML 文字列として扱うかどうか |
boolean | — | false |
customClass | メッセージ用カスタムクラス名 | string | — | — |
duration | 表示時間、ミリ秒。0に設定した場合、自動的にはオフになりません。 | number | — | 3000 |
showClose | 閉じるボタンを表示するかどうか | boolean | — | false |
center | テキストを中央に配置するかどうか | boolean | — | false |
onClose | メッセージのインスタンスをパラメータにして閉じた場合のコールバック関数 | function | — | — |
offset | ビューポートの上端までの距離を設定します | number | — | 20 |
メソッド
Message
と this.$message
は現在の Message インスタンスを返します。インスタンスを手動で閉じるには、そのインスタンスに対して close
を呼び出すことができます。
Method | Description |
---|---|
close | メッセージを閉じる |