如何在“节点/[NID]”页面上显示编辑表单


how to show edit form on the "node/[nid]" page?

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

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]/

编辑到节点/[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。

我做错了什么?

我使用了函数 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函数函数node_add($type