我正在开发一个非常简单的类(class)目录。我正在使用动态选择下拉菜单来显示特定学院提供的类(class)。最初,我在这些选择菜单中显示了 可用类(class) 的完整列表,其中的值来自名为 courses_selection_list 的 mysql 数据库表。然后,我通过标记值 selected=selected 来选择 academy_id=15 提供的类(class)。在 Jquery/JS 中,您会看到我正在对文件 getCourses.php 进行一次 ajax 调用。然后在页面加载时显示选择菜单。
我的问题如下:我只能显示 academy_id=15 提供的类(class)的一个值。我怎样才能显示它们?或者有更好的方法吗? DEMO
<script>
var option = $('#courses_offered').val();
showFields(option);
function showFields(option){
var content = '';
for (var i = 1; i <= option; i++){
var content = '';
for (var i = 1; i <= option; i++){
(function(i) {
$.ajax({
type: "POST",
url: "getCourses.php",
data: {
value: option
},
success: function (data) {
content += '<div id="course_'+i+'">'
+'<label>Course # '+i+'</label><br />'
+'<label>Course Name:</label>'
+'<select id="coursename_'+i+'" name="coursename_'+i+'" class="course_list">'
+'<option value="" >--- Select ---</option>"';
content += data;
content += '</select></div></br>';
$('#course_catalog').html(content);
}
});
})(i);
}
$('#course_catalog').html(content);
}
$('#course_catalog').html(content);
}
</script>
<select name="courses_offered" id="courses_offered" disabled>
<?php
$db_select2 = $db_con->prepare("
SELECT academy_id
FROM courses_by_academy
WHERE academy_id = :id
");
if (!$db_select2) return false;
if (!$db_select2->execute(array(':id' => $id))) return false;
$courses_count = $db_select2->rowCount();
echo "<option>----Select----</option>";
echo "<option value=\"1\"". (($courses_count=="1")?"selected=\"selected\"":"") .">1</option>";
echo "<option value=\"2\"". (($courses_count=="2")?"selected=\"selected\"":"") .">2</option>";
echo "<option value=\"3\"". (($courses_count=="3")?"selected=\"selected\"":"") .">3</option>";
echo "<option value=\"4\"". (($courses_count=="4")?"selected=\"selected\"":"") .">4</option>";
echo "<option value=\"5\"". (($courses_count=="5")?"selected=\"selected\"":"") .">5</option>";
?>
</select>
<div id="course_catalog"></div>
getCourses.php - 类(class)值(value)
$id = 15;
//get the course list
$course_query = $db_con->prepare("SELECT course_id, course_name FROM courses_selection_list;");
$course_query->execute();
$data = $course_query->fetchAll();
foreach ($data as $row){
//select the courses being offered by academy_id=15
$option = "<option value='".$row["course_id"].":".$row["course_name"]."'";
$db_select = $db_con->prepare("
SELECT academy_id, course_name, course_id,
course_start_date, course_end_date
FROM courses_by_academy
WHERE academy_id = :id
");
if (!$db_select) return false;
if (!$db_select->execute(array(':id' => $id))) return false;
$results = $db_select->fetchAll(\PDO::FETCH_ASSOC);
if (empty($results)) return false;
foreach ($results as $value) {
$result= $value['course_id'];
if ($result == $row['course_id']) {
$option .= "selected='selected'";
}
}
$option .= ">". $row['course_name'] ."</option>";
//show result
echo $option;
}
Mysql 表示例:
courses_selection_list
+-----------+-------------------------+
| course_id | course_name |
+-----------+-------------------------+
| 1 | Math |
| 2 | English |
| 3 | Science |
| 4 | Other- Not Listed |
| 5 | Social Studies |
| 6 | Home Mac |
| 7 | Business Management |
| 8 | Psychology |
| 9 | Accounting |
| 10 | Advanced Networks |
| 11 | Information Techonology |
+-----------+-------------------------+
courses_by_academy
+----+------------+--------------------------+-----------+------------+----------+
| id | academy_id | course_name | course_id | start_date |end_date |
+----+------------+--------------------------+-----------+------------+----------+
| 1 | 15 | Science | 3 |2013-12-04 |2013-12-25|
| 2 | 15 | Business Management | 7 |2013-12-04 |2013-12-25|
| 3 | 15 | Information Technology | 11 |2013-12-04 |2013-12-25|
+----+------------+--------------------------+-----------+------------+----------+
期望的结果:
最佳答案
Javascript 插入 document.ready 事件
var option = 3,
$course_catalog = $('#course_catalog');
showFields(option);
function showFields(option){
$course_catalog.html('');
// request only once
$.ajax({
type: "POST",
url: "getCourses.php",
async : false,
data: {
value : option
},
dataType : 'json',
contentType : 'application/json',
success: function (data) {
for (var i = 1; i <= option; i++){
// prepare select
$course_catalog.append('<div id="course_' + i + '"><label>Course # '+i+'</label><br />'
+'<label>Course Name:</label>'
+'<select id="coursename_'+i+'" name="coursename_'+i+'" class="course_list">'
+'<option value="" >--- Select ---</option>"'
+'</select><br/><p id="date_'+i+'"></p></div></br>');
var $el = $course_catalog.find('#coursename_' + i),
val = 0,
index = 1;
for(var n in data) {
var o = data[n];
if (o.academy_id > 0) {
if (index == i) {
val = o.id + ':' + o.name;
$course_catalog.find('#date_'+i).html('Start at: ' + o.start_date + ' until '+o.end_date);
}
index ++;
}
$el.append('<option value="' + o.id + ':' + o.name + '">'+o.name+'</option>');
}
$el.val(val);
}
}
});
}
PHP代码:
header("Content-type: application/json");
$id = 15;
//get the course list
$course_query = $db_con->prepare("
SELECT
t.course_id, t.course_name, IFNULL(lj.academy_id, 0) as academy_id, lj.course_start_date, lj.course_end_date
FROM courses_selection_list as t
LEFT JOIN courses_by_academy as lj
ON (lj.course_id = t.course_id AND lj.academy_id = :id)
ORDER BY t.course_id
");
$course_query->execute(array(':id' => $id));
$data = $course_query->fetchAll();
$course_data = array();
foreach ($data as $row) {
$course_data[] = array(
"id" => $row["course_id"],
"name" => $row["course_name"],
"academy_id" => $row["academy_id"],
"start_date" => $row["course_start_date"],
"end_date" => $row["course_end_date"],
);
} // foreach ($data as $row) {
echo json_encode($course_data);
关于javascript - 从 mysql 表中获取值并显示在下拉菜单中选择的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20810237/
我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
所以我在关注Railscast,我注意到在html.erb文件中,ruby代码有一个微弱的背景高亮效果,以区别于其他代码HTML文档。我知道Ryan使用TextMate。我正在使用SublimeText3。我怎样才能达到同样的效果?谢谢! 最佳答案 为SublimeText安装ERB包。假设您安装了SublimeText包管理器*,只需点击cmd+shift+P即可获得命令菜单,然后键入installpackage并选择PackageControl:InstallPackage获取包管理器菜单。在该菜单中,键入ERB并在看到包时选择
我试图在索引页中创建一个超链接,但它没有显示,也没有给出任何错误。这是我的index.html.erb代码。ListingarticlesTitleTextssss我检查了我的路线,我认为它们也没有问题。PrefixVerbURIPatternController#Actionwelcome_indexGET/welcome/index(.:format)welcome#indexarticlesGET/articles(.:format)articles#indexPOST/articles(.:format)articles#createnew_articleGET/article
我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c
有没有办法在这个简单的get方法中添加超时选项?我正在使用法拉第3.3。Faraday.get(url)四处寻找,我只能先发起连接后应用超时选项,然后应用超时选项。或者有什么简单的方法?这就是我现在正在做的:conn=Faraday.newresponse=conn.getdo|req|req.urlurlreq.options.timeout=2#2secondsend 最佳答案 试试这个:conn=Faraday.newdo|conn|conn.options.timeout=20endresponse=conn.get(url
我有一个存储主机名的Ruby数组server_names。如果我打印出来,它看起来像这样:["hostname.abc.com","hostname2.abc.com","hostname3.abc.com"]相当标准。我想要做的是获取这些服务器的IP(可能将它们存储在另一个变量中)。看起来IPSocket类可以做到这一点,但我不确定如何使用IPSocket类遍历它。如果它只是尝试像这样打印出IP:server_names.eachdo|name|IPSocket::getaddress(name)pnameend它提示我没有提供服务器名称。这是语法问题还是我没有正确使用类?输出:ge
我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c
我安装了ruby版本管理器,并将RVM安装的ruby实现设置为默认值,这样'哪个ruby'显示'~/.rvm/ruby-1.8.6-p383/bin/ruby'但是当我在emacs中打开inf-ruby缓冲区时,它使用安装在/usr/bin中的ruby。有没有办法让emacs像shell一样尊重ruby的路径?谢谢! 最佳答案 我创建了一个emacs扩展来将rvm集成到emacs中。如果您有兴趣,可以在这里获取:http://github.com/senny/rvm.el
假设我有这个范围:("aaaaa".."zzzzz")如何在不事先/每次生成整个项目的情况下从范围中获取第N个项目? 最佳答案 一种快速简便的方法:("aaaaa".."zzzzz").first(42).last#==>"aaabp"如果出于某种原因你不得不一遍又一遍地这样做,或者如果你需要避免为前N个元素构建中间数组,你可以这样写:moduleEnumerabledefskip(n)returnto_enum:skip,nunlessblock_given?each_with_indexdo|item,index|yieldit