ノード入力時、指示(パラメータ)を渡し、特定のフォームに初期値を設定したり、入力不可にしたい場合があります。
ノード入力フォームにおけるパラメータの渡し方と、使い方を教えて下さい。
ノード入力フォームへパラメータを渡す
OTHER FAQ
カテゴリ | Core Ver. | 関連モジュール | タイトル |
---|---|---|---|
コンテンツの作成 | 7.26 | Form Ajax | 入力フォームで#ajax使用時、#default_valueを書き換えても反映しない |
コンテンツの作成 | 7.15 | Automatic_Nodetitles Automatic_Entity_Label | ノード投稿フォームにタイトル入力フォームを表示しない方法 |
コンテンツの作成 | 8.9.x | CSS | キャプション付きの(右寄/左寄)画像を画像サイズを基準にきれいに表示する方法 |
コンテンツの作成 | 8.4x | コンテンツ作成時のフォームレイアウトの変更 | |
コンテンツの作成 | 8.4x | PhpSpreadsheet | Excelを読み書きする方法 |
コンテンツの作成 | 7.15 | Mailhandler | メールを通じてnodeの投稿をするには |
コンテンツの作成 | 6.x | Views | カルーセルのように回転するコンテンツを作りたい |
コンテンツの作成 | 7.38 | Webform | Webformでテーブル形式にしたい |
コンテンツの作成 | 7.50 | Code per Node | ページ毎にCSSやJSを設定したい |
コンテンツの作成 | 7.38 | node | 代理投稿を可能にしたい |
コンテンツの作成 | 8.9.x | Display sweet, Views, Twig Tweak, Views field formatter | テーマに頼らず コンテンツのフィールドとしてViewsを埋め込み表示する方法 |
コンテンツの作成 | 7.23 | maxlength | テキストフィールドの最大長のチェック&カウントダウン |
コンテンツの作成 | 7.26 | PHP | ノード内の一部(フィールド)を変更する |
コンテンツの作成 | 8.4x | Download | とにかく何でもコンテンツをダウンロードさせる方法 |
コンテンツの作成 | 7.34 | CCK | ノード入力フォームへパラメータを渡す |
コンテンツの作成 | 7.22 | node Views | ノードに付いたコメントに関する情報を得る |
コンテンツの作成 | 8.4x | node | 新規ノードを作成する |
コンテンツの管理 | 8.9.x | 写真の変更を行いたい | |
コンテンツの管理 | 6.x | Views Flag Calendar | 空き室予約のような仕組みは実現できますか? |
コンテンツの管理 | 8.4x | Action | カスタムアクションを作成する方法 |
コメント
下記のような形が最も良いと思います。
パーマリンク Submitted by actbrain on 2014/12/15 15:10.
下記のような形が最も良いと思います。
1.ノード新規作成時、や更新時のリンクにパラメータを乗せる。
2.hook_form_alter()でパラメータによるフォーム変更を行う。
以下に例を示します。
1.リンク
1)ノード新規作成:node/add/{your node-type}/パラメータ1/...
2)既存ノード変更:node/{node id}/edit/パラメータ1/...
2.hook_form_alter()
〜
function {your module name}_form_alter(&$form, $form_state, $form_id) {
switch ($form_id) {
case '{your node-type}_node_form':
if (strlen(arg(3))) {
$is_add = arg(0) == 'node' && arg(1) == 'add' & empty($form['nid']['value']);
$is_edit = arg(0) == 'node' && arg(2) == 'edit' & !empty($form['nid']['value']);
if ($is_add || $is_edit) {
// 初期値を設定し、変更禁止にする
$form['{initial field name}']['und'][0]['#default_value'] = arg(3);
$form['{initial field name}']['und'][0]['#disabled'] = TRUE;
}
}
}
}
}
〜
ページ