0

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

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。

我究竟做错了什么?

4

1 回答 1

1

我使用了函数 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

于 2013-09-30T19:06:31.707 回答