ホームページ  >  記事  >  ウェブフロントエンド  >  formStorage は、jquery に基づくプラグインです (フォーム内の要素のステータスをローカルに保存します)_jquery

formStorage は、jquery に基づくプラグインです (フォーム内の要素のステータスをローカルに保存します)_jquery

WBOY
WBOYオリジナル
2016-05-16 17:56:451160ブラウズ

原理は非常に単純で、ローカル ストレージ メカニズム (userData または localStorage) を通じて、フォーム内の要素のステータスがローカルに保存され、必要に応じて保存されたステータスをフォーム要素に復元できます。

プラグインに必要な関数を最初から書きたかったのですが、冗長すぎるため、他の 2 つのプラグインをベースにしました。

>

は、jquery.jsonjStorage です。これら 2 つのプラグイン自体は実用的でコンパクトで、API はシンプルで使いやすいです。古いブラウザ (ネイティブ JSON をサポートしていない) で一般的な操作) には jquery.json または json2

が必要です。

formStorage は 3 つのメソッドを jQuery オブジェクトに拡張しますが、これらはフォーム以外のタグには無効です。

保存時に呼び出します: $('#myform').formStore(/*excludes*/), このメソッドは、フォーム要素 ID を含む配列を渡して、どの要素ステータスが必要ないのかを指定できます。保存されます

復元時に呼び出されます: $('#myform').formRestore()

ストレージのクリア呼び出し: $('#myform').destroyStore()、対応するローカル ストレージ データが削除されているため、その後の formRestore の呼び出しは機能しません

: 復元時に要素を見つけるには、フォームとそのフォーム要素の両方に id、保存時にフォームの ID をキーとして使用し、すべてのフォーム要素のステータスが値として json 文字列に編成されます。

入力タイプがボタン、ファイル、送信、リセット、パスワード、イメージのいずれかの場合、フォーム内にテキストエリアがある場合、ラベルのステータスは保存されません。テキストコンテンツが大きい、

特に IE6 および 7 では、実際の使用は推奨されません。

以下は、各ブラウザのローカル ストレージ容量の参考図です (jStorage のホームページより):

わかりました、写真のブラウザは少し古いようです...

以下は簡単な例です:



コードをコピーします コードは次のとおりです:





<入力タイプ="ラジオ" 名前="ラジオ名" id="ラジオ2" 値="ラジオ値2" />
<名前を選択= selectoptions" id=" select1">


<オプション値="オプション2">オプション2
<オプション値="オプション3">オプション3
id="area" cols="30" rows="10">

>
form>


例の対応する js は次のとおりです:



コードをコピー
コードは次のとおりです。次のように: $('#store, #restore, #destroy').on('click', function() { if(this.id == 'store') $('#myform').formStore();
else if(this.id == 'restore')
$('#myform').formRestore(); 🎜>$('#myform').destroyStore ();
});


最後に、興味がある場合は、このプラグインをダウンロードできます (クリックしてダウンロードします
formStorage
) を解凍して、HTML 内で直接テストを実行するだけで十分です。ソース コードは圧縮されていません。時間が短いため、不完全な点があるかもしれません。議論のためにメッセージを残してください。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。