我需要为我的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设置了这个很酷的网站。是否有像这样的语言
答案 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。