JSON は JavaScript のハイライトとも言え、オブジェクトと配列の初期化をエレガントで簡潔なコードで実装できます。これはテキストベースのデータ定義でもあり、シンボル分離よりも意味論的であり、XML よりも簡潔です。そのため、JS 開発者がデータの送信やストレージとして使用することが増えています。
JS 配列には、データのクエリとフィルタリングを容易にするための便利なメソッドが多数組み込まれています。たとえば、一連のデータがあります:
コードをコピーします
コードは次のとおりです:
関数テンプレートの概要
C にはマクロやクラス テンプレートなどがあり、コンパイル フェーズ中に一部の計算を完了できるようになり、パフォーマンスが大幅に向上します。ランタイムコード。スクリプトは厳密な意味ではコンパイルされませんが、初回実行時に解析されて完全に最適化されます。これが現在の主流ブラウザ間の競争点です。したがって、事前に用意されているテンプレート関数に繰り返し eval コードを埋め込む必要があります。準備が整い、式の計算のみが必要な関数:コードをコピー
コードは次のとおりです:
for(var i = 0; i
if($express) {
🎜>上記は、パラメーター arr [] を走査し、$express に一致する数をカウントするテンプレート関数です。 if(...) 内の式を除いて、他のすべての準備は完了です。文字 $express は、関数内の他の文字と競合しない限り、他の識別子に置き換えることもできます。
インスタンスを作成する必要がある場合は、まず tmplCount.toString() を通じて関数を文字列形式に変換し、次に $express を必要な式に置き換え、最後にこの文字列を評価して関数タイプの変数、インスタンスを取得します。のテンプレート関数が生成されました!
簡単なデモを行ってみましょう:
コードをコピーします
コードは次のとおりです:
{名前: 'アダム'、年齢: 18}
];
var f1 = createInstance('e.agealert(f1(student));
//demo2
var f2 = createInstance('e.name!="ジャック" && e.age>=14');
alter(f2(student)); //2
実際、率直に言うと、tmplCount はこの関数の文字列を提供するためだけに存在しており、それ自体が呼び出されることはありません。実際、文字列形式での定義は同じですが、関数で記述した方が直感的でテストに便利です。
後でスクリプトで圧縮の最適化が必要な場合は、tmplCount テンプレートを使用しないでください。使用しないと、対応する "e." と "$express" が変更される可能性があることに注意してください。
関数テンプレートの使用と実装を紹介したので、前の JSON クエリ言語を振り返ってみましょう。 SQL のようなステートメントを JS 式に変換し、関数テンプレートのインスタンスを生成するだけで済みます。同じステートメントについては、毎回の変換を避けるためにキャッシュすることができます。
最初にクエリ テンプレートを実装します。コードをコピーします
コードは次のとおりです。 // for(var _k in _list) { 次に、オブジェクトの select メソッドの記述を開始します: var code = __interpret(exp); //式を解釈します
var __proto = Object.prototype;
// テンプレート: __tmpl
// パラメータ: $C
// 説明: $C に一致する要素のセットを _list オブジェクトに記録して返します
//
var __tmpl = function(_list) {
var _ret = [];
var _i = -1;
var _e = _list[_k];
if(_e && _e != __proto[_k]) {
if ($C)
}.toString();
コードをコピー
__proto.select = function(exp) {
If(!exp)
return [];
var fn = __cache[exp];
try { if(!fn) {
fn = __cache [exp] = __compile(code);
return fn(this); }
}
__cache テーブルはクエリ ステートメントのキャッシュを実装します。クエリを繰り返すと、パフォーマンスが大幅に向上します。
コードをコピー
コードは次のとおりです。
function __compile() {
jsonselect.rar
デモンストレーションの目的で、現在はいくつかの基本機能のみが実装されています。将来的には、LIKE、BETWEEN、ORDER BY などの一般的に使用される関数を追加することもできます。
デモ
コードは次のとおりです:
// 名前 ===================== パワー === アジャイル == === インテリジェンス == ==
{name:'アイスハウスウィッチ'、DP:38、AP:1.3、Str:16、Agi:16、Int:21}、
{name:'サイレントウォーロック'、DP:39、AP :1.1、Str:17、Agi:16、Int:21}、
21, 8}、
{名前:'バウンティハンター'、DP:39、AP:4.0、Str:17、Agi :21, Int:16},
{name:'ヴェノマンサー' ', DP:45, AP:3.1, Str:18, Agi:22, Int:15},
{name:'光の守護者'、DP:38、AP:1.1、Str:16、Int:22}、
// クエリ:
"Scholar" で終わる // 結果: サイレンス ウォーロック、ヴェノマンサー、アルケミスト var match = hero.select('right(@name,1)="Shi" ');
// クエリ: 体力が 500 を超える
// 結果: Alchemist