AI翻訳通知
このドキュメ ントはAIによって翻訳されました。正確な情報については英語版をご参照ください。
JS Field
介绍
JS Field は、フィールドの位置で JavaScript を使用してコンテンツをカスタムレンダリングするために使用されます。詳細ブロック、フォームの読み取り専用項目、またはテーブル列の「その他のカスタム項目」などでよく見られます。パーソナライズされた表示、派生情報の組み合わせ、ステータスバッジ、リッチテキスト、またはチャートなどのレンダリングに適しています。

类型
- 読み取り専用型:編集不可の表示に使用され、
ctx.valueを読み取って出力をレンダリングします。 - 編集可能型:カスタム入力インタラクションに使用され、
ctx.getValue()/ctx.setValue(v)とコンテナイベントjs-field:value-changeを提供し、フォーム値との双方向同期を容易にします。
使用场景
-
読み取り専用型
- 詳細ブロック:計算結果、ステータスバッジ、リッチテキストのスニペット、チャートなどの読み取り専用コンテンツを表示します。
- テーブルブロック:「その他のカスタム列 > JS Field」として読み取り専用表示に使用されます(フィールドにバインドされていない列が必要な場合は、JS Column を使用してください)。
-
編集可能型
- フォームブロック(CreateForm/EditForm):カスタム入力コントロールや複合入力に使用され、フォームのバリデーションや送信に付随します。
- 適したシーン:外部ライブラリの入力コンポーネント、リッチテキスト/コードエディタ、複雑な動的コンポーネントなど。
运行时上下文 API
JS Field のランタイムコードは、以下のコンテキスト機能を直接使用できます。
ctx.element:フィールドの DOM コンテナ(ElementProxy)。innerHTML、querySelector、addEventListenerなどをサポートしています。ctx.value:現在のフィールド値(読み取り専用)。ctx.record:現在のレコードオブジェクト(読み取り専用)。ctx.collection:フィールドが属するコレクションのメタ情報(読み取り専用)。ctx.requireAsync(url):URL に基づいて AMD/UMD ライブラリを非同期でロードします。ctx.importAsync(url):URL に基づいて ESM モジュールを動的にインポートします。ctx.openView(options):設定済みのビュー(ポップアップ/ドロワー/ページ)を開きます。ctx.i18n.t()/ctx.t():国際化。ctx.onRefReady(ctx.ref, cb):コンテナの準備が整ってからレンダリングします。ctx.libs.React/ctx.libs.ReactDOM/ctx.libs.antd/ctx.libs.antdIcons/ctx.libs.dayjs/ctx.libs.lodash/ctx.libs.math/ctx.libs.formula:組み込みの React / ReactDOM / Ant Design / Ant Design アイコン / dayjs / lodash / math.js / formula.js などの共通ライブラリで、JSX のレンダリング、時間処理、データ操作、数学演算に使用されます。(ctx.React/ctx.ReactDOM/ctx.antdは互換性のために引き続き保持されます。)ctx.render(vnode):React 要素、HTML 文字列、または DOM ノードをデフォルトコンテナctx.elementにレンダリングします。繰り返しレンダリングすると Root が再利用され、コンテナの既存のコンテンツが上書きされます。
編集可能 型(JSEditableField)特有の機能:
ctx.getValue():現在のフォーム値を取得します(フォームの状態を優先し、次にフィールドの props にフォールバックします)。ctx.setValue(v):フォーム値とフィールドの props を設定し、双方向同期を維持します。- コンテナイベント
js-field:value-change:外部の値が変化したときにトリガーされ、スクリプトが入力表示を更新しやすくなります。
编辑器与片段
JS Field のスクリプトエディタは、構文ハイライト、エラーヒント、および組み込みコードスニペット(Snippets)をサポートしています。
Snippets:組み込みコードスニペットのリストを開き、検索して現在のカーソル位置にワンクリックで挿入できます。Run:現在のコードを直接実行します。実行ログは下部のLogsパネルに出力され、console.log/info/warn/errorとエラーのハイライト表示による位置特定をサポートしています。

AI 従業員と連携してコードを生成することもできます:
常见用法
1) 基础渲染(读取字段值)
2) 使用 JSX 渲染 React 组件
3) 加载第三方库(AMD/UMD 或 ESM)
4) 点击打开弹窗/抽屉(openView)
5) 可编辑输入(JSEditableFieldModel)
注意事项
- 外部ライブラリのロードには信頼できる CDN を使用することを推奨し、失敗シナリオに備えてフォールバック(例:
if (!lib) return;)を用意してください。 - セレクタは
classまたは[name=...]を優先的に使用し、固定idの使用は避けてください。これにより、複数のブロックやポップアップでのidの重複を防ぎます。 - イベントのクリーンアップ:フィールドはデータの変更やビューの切り替えにより複数回再レンダリングされる可能性があるため、イベントをバインドする前にクリーンアップまたは重複排除を行い、重複トリガーを避けてください。「先に remove してから add する」ことが可能です。

