如何在“node / [nid]”页面上显示编辑表单?

时间:2013-09-30 18:40:39

标签: php drupal drupal-7

我有内容类型(预算),它是自定义内容类型

function budget_node_info() {
  return array(
    'budget' => array(
      'base' => 'budget',
      'name' => t('Budget'),
      'description' => t('Represents individual budget.'),
      'title_label' => t('Budget Name'),
      'locked' => TRUE
    )
  );
}

我也有表格功能

function budget_form($node, $form_state) {
  drupal_add_library('system', 'ui.tabs');
  drupal_add_library('budget', 'highcharts');
  drupal_add_js(drupal_get_path('module', 'budget') . '/js/budget_base.js');
  drupal_add_js(drupal_get_path('module', 'budget') . '/js/' . $node->type . '.js');

  $form = node_content_form($node, $form_state);
  $config = variable_get($node->type);

我想在节点视图页面上显示编辑表单(我想从节点/ [nid] / edit到节点/ [nid]显示表单)?

我接下来试过了:

function budget_node_view($node, $view_mode, $langcode){
  $node->content['edit-form'] = array(
    '#markup' => render(drupal_get_form('budget_form', $node)),
    '#weight' => 10,
  );
}

我也试过

function budget_node_view($node, $view_mode, $langcode){
  $node->content['edit-form'] = array(
  '#markup' => render(budget_form($node, array())),
    '#weight' => 10,
  );
}

第二版显示表单,但没有加载任何js或css。

我做错了什么?

1 个答案:

答案 0 :(得分:1)

我使用了function node_page_edit($node),似乎有效

function wp_budget_node_view($node, $view_mode, $langcode){
  module_load_include('inc', 'node', 'node.pages');
  $node->content['edit-form'] = array(
    '#markup' => render(node_page_edit($node)),
    '#weight' => 10,
  );
}

对于新(空)表单,您应该使用node_add函数function node_add($type