vue.js
に基づいており、他のプラグインやライブラリに依存せず、基本的なものです。機能は維持されています。 element-ui と一貫して、モバイルの違いに合わせていくつかの内部実装調整が行われています。
現在の構築プラットフォームは uni-app 公式スキャフォールディングを使用して構築されています。現在のモバイル端末のほとんどは h6
と WeChat アプレット
であるため、1 つのコード セットが必要です複数の端末で動作できるため、技術的な選択に非常に適しています。
Core api: <form></form>
および <form-item> に対応する、provide と inject を使用します。 ###。 </form-item>
$off、
$ が vue3
のエミットから削除されたため、したがって、
uni.$on、
uni.$off、および
uni.$emit が代わりに使用されます。違いは、このイベントがディスパッチ メカニズムであることです。はグローバルであり、コンポーネントの一意性に従いません。そのため、イベントを追加または削除するときは、イベント名に一意の値を設定する必要があります。ここでは、
triggerこのイベント設定は不要になりました;
pattern は
reg に置き換えられます。WeChat アプレットでは、コンポーネントによって渡されたパラメータはフィルタリングされ、基本はそのまま残されることに注意してください。
json 型なので、この
reg をミニ プログラム環境で使用する場合は、最後に
.toString() を追加する必要があります (
validator##)。 #も同じ理由です。 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;">/** 表单规则类型 */
export interface TheFormRulesItem {
/** 是否必填项 */
required?: boolean
/** 提示字段 */
message?: string
/** 指定类型 */
type?: "number" | "array"
/**
* 自定义的校验规则(正则)
* - 考虑到微信一些特殊的抽风机制,在微信小程序中,除`number|string|object|undefined|null`这几个基础类型外,其他类型是会被过滤掉,所以这里在写正则的时候,在末尾加上`.toString()`即可
*/
reg?: string // | RegExp
}
/** 表单规则类型 */
export type TheFormRules = { [key: string]: Array<TheFormRulesItem> };</pre><div class="contentsignin">ログイン後にコピー</div></div>
フォーム検証のトリガー メカニズム:
element-uivalidate、
validateField 検証メソッドを積極的に呼び出して実際のトリガーをトリガーすることでした。検証に失敗した場合は変数に格納し、データが変更されるたびに検証し、検証が成功したらリアルタイム検証項目を削除することで、
element- と比較します。 uiバインディング イベント、リアルタイム検証により、多くのコードの呼び出しと実行メカニズムが節約され、コードがより洗練され、合理化されます。
除了更换标签之外,几乎不用做任何的修改就可以复制粘贴到其他项目中去,唯一要修改的就是自定义事件uni.$on
、uni.$off
和uni.$emit
;这里可以自己实现,又或者用其他库去代替,js
实现自定义事件派发代码如下:
function moduleEvent() { /** * 事件集合对象 * @type {{[key: string]: Array<Function>}} */ const eventInfo = {}; return { /** * 添加事件 * @param {string} name 事件名 * @param {Function} fn 事件执行的函数 */ on(name, fn) { if (!eventInfo.hasOwnProperty(name)) { eventInfo[name] = []; } if (!eventInfo[name].some(item => item === fn)) { eventInfo[name].push(fn); } }, /** * 解绑事件 * @param {string} name 事件名 * @param {Function} fn 事件绑定的函数 */ off(name, fn) { const fns = eventInfo[name]; if (fns && fns.length > 0 && fn) { for (let i = 0; i < fns.length; i++) { const item = fns[i]; if (item === fn) { fns.splice(i, 1); break; } } } else { console.log("[moduleEvent] => 没有要解绑的事件"); } }, /** * 调用事件 * @param {string} name 事件名 * @param {any} params 事件携带参数 */ dispatch(name, params) { const fns = eventInfo[name]; if (fns && fns.length > 0) { for (let i = 0; i < fns.length; i++) { const fn = fns[i]; fn(params); } } else { console.log("[moduleEvent] => 没有要执行的事件"); } }, } }
调用moduleEvent()
之后,用变量调用即可,注意当前变量要作为内存常驻使用。
以上がvue3 で H5 フォーム検証コンポーネントを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。