如何在drupal表下拉列表中创建所有语言的数组

时间:2014-03-27 06:20:11

标签: php arrays drupal drupal-7 lang

我需要为我的Drupal表单中的所有语言创建下拉列表,PHP中是否有任何功能可以实现此目的。我想创建一个包含所有语言的数组并将其传递给drupal形式。

function video_upload_subtitles_form($form, &$form_state) {
 $form = array('#attributes' => array('enctype' => 'multipart/form-data'));
 $lang_list = array();//**how to create this array**
 $form['video_name'] = array(
    '#title' => t('Name Of the video'),
    '#type' => 'textfield',
 );

 $form['sub_file'] = array(
        '#type' => 'file',
        '#title' => t('Upload video'),
        '#description' => t('Pick a video file to upload.'),
    );
$form['user_list']=array(
    '#type'=>'select',
    '#title' => t('Language'),
    '#options' => $lang_list,//array of language
    '#multiple' => false,
    '#attributes'=>array('size'=>4),
    '#weight'=>8,
);
 $form['submit_button'] = array(
    '#type' => 'submit',
    '#value' => t('Submit'),
 );

 return $form;

}

我知道语言列表可以通过列表和手动制作数组来完成,但是可以使用任何PHP函数,只是寻找一些简单的方法来节省时间。

Country List设置了这个很酷的网站。是否有像这样的语言

2 个答案:

答案 0 :(得分:1)

试试这个,

    $select = db_select('Your table name', 's');
    $select = $select->fields('s',array('languages_name','id'));
    // 'languages_name' , 'id' this is a column
    $queried_nodes = $select->execute()
    ->fetchAllAssoc('id');
    $lang_list = array();
    foreach ($queried_nodes as $result)
    {   
       $lang_list[$result->languages_name] = t($result->languages_name);
    }

设置$ lang_list变量后

$form['user_list']=array(
     '#type'=>'select',
     '#title' => t('Language'),
     '#options' => $lang_list,//array of language
     '#multiple' => false,
     '#attributes'=>array('size'=>4),
     '#weight'=>8,
);

您正在创建一个新的语言表或内容类型,并使用drupal内置语言列表,请尝试使用此代码。

  include_once DRUPAL_ROOT . '/includes/iso.inc';
  $lang = _locale_get_predefined_list();

  $lang_list = array();

  foreach ($lang as $key => $value) 
  {
    $lang_list[$value[0]] = t($value[0]);
  }

在形式api

中使用$lang_list变量后

答案 1 :(得分:0)

最简单的方法可能是将所需的所有语言放在数据库的表中。

然后您可以使用以下代码创建您的选择框:

$languages = db_query("SELECT id, name FROM languages")->fetchAllKeyed();

$form['language'] = array(
    '#type' => 'select',
    '#title' => t('Choose language'),
    '#options' => $languages,
);

要填充您的语言表,您可以下载csv here