重复 javascript 功能,而无需在脚本中使用相同代码的多个实例
我没有 Java 脚本的工作知识,并且正在尝试了解它。
我有一个带有表格的 PHP 页面。该行的第一列有一个下拉列表。当 onclick 事件被触发时,它会根据 php mysql 查询填充行中的其他单元格。
问题是我的表最多可以包含 75 行,因为它是订单页面的表。我不想使用不同的指针使用相同的 javascrot 代码 75 次?
有没有更简单的方法来优化页面并降低页面复杂性? (document.getElementById("txtHint1").innerHTML="";)
我可以使用 $(this) 吗?如果是这样我该如何整合它?否则我有什么选择?
我的 php 页面如下。目前它适用于两行,但我需要配置 75 行。
<html>
<head>
<script type="text/javascript">
function showUser1(str)
{
if (str=="")
{
document.getElementById("txtHint1").innerHTML="";
return;
}
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("txtHint1").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getdata1.php?q="+str,true);
xmlhttp.send();
}
</script>
<script type="text/javascript">
function showUser2(str)
{
if (str=="")
{
document.getElementById("txtHint2").innerHTML="";
return;
}
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("txtHint2").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getdata1.php?q="+str,true);
xmlhttp.send();
}
</script>
</head>
<body>
<?
$con = mysql_connect('localhost', 'unilekxy_UL', 'Unilever2011');
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("unilekxy_unilever", $con);
$skusql="SELECT packcode,concat(packcode, ' - ' , description) as description from skudata";
$resultsku=mysql_query($skusql);
$optionssku="";
while ($row=mysql_fetch_array($resultsku)) {
$sku=$row["packcode"];
$description=$row["description"];
$optionssku.="<OPTION VALUE=\"$sku\">".$description;
}
?>
<table border=1>
<tr>
<td width=393>Product</td>
<td width=200>Category</td>
<td width=150>Selling Unit</td>
<td width=150>Grouping</td>
<td width=150>Full Case QTY</td>
</tr>
</table>
<table>
<tr>
<td>
<select name="users" onchange="showUser1(this.value)" size=1>
<OPTION VALUE=0>
<?=$optionssku?>
</SELECT>
</td>
<td>
<div id="txtHint1"><b>SKU Details will be seen here</b></div>
</td>
</tr>
<tr>
<td>
<select name="users" onchange="showUser2(this.value)" size=1>
<OPTION VALUE=0>
<?=$optionssku?>
</SELECT>
</td>
<td>
<div id="txtHint2"><b>SKU Details will be seen here</b></div>
</td>
</tr>
</table>
</body>
</html>
被调用来执行 mysql 的 php 页面是
<?php
$q=$_GET["q"];
$con = mysql_connect('localhost', 'dbuser', 'dbpass');
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("unilekxy_unilever", $con);
$sql="SELECT Category, SellingUnits,Grouping,CasesPerPallet,ShrinksPerPallet FROM skudata WHERE packcode = '".$q."'";
$result = mysql_query($sql);
while($row = mysql_fetch_array($result))
{
echo "<table border=1><tr>";
echo "<td width=200>".$row['Category']."</td>";
echo "<td width=150>".$row['SellingUnits']."</td>";
echo "<td width=150>".$row['Grouping']."</td><td width=150>";
if($row['SellingUnits']=="CS"){echo $row['CasesPerPallet'];} elseif($row['SellingUnits']=="SHR") {echo $row['ShrinksPerPallet'];}
echo "</td></tr></table>";
}
mysql_close($con);
?>
感谢 advane 的帮助, 瑞安
I have no working knowledge of Java script and am trying to get into it.
I have a PHP page with a table. The first column of the row has a drop down list. when the onclick event is triggered it populates the other cells in the row based on a php mysql query.
The problem is that my table can consist of up to 75 rows as it is for an order page. I'd prefer not to have the same javascropt code 75 times with a different pointer?
is there an easier way to do this in order to optimize the page and reduce the page complexity? (document.getElementById("txtHint1").innerHTML="";)
Can I use $(this) at all? if so how do I integrate it? otherwise what are my options?
My php page is as below. currently it works with two rows however i need to provision for 75 rows.
<html>
<head>
<script type="text/javascript">
function showUser1(str)
{
if (str=="")
{
document.getElementById("txtHint1").innerHTML="";
return;
}
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("txtHint1").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getdata1.php?q="+str,true);
xmlhttp.send();
}
</script>
<script type="text/javascript">
function showUser2(str)
{
if (str=="")
{
document.getElementById("txtHint2").innerHTML="";
return;
}
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("txtHint2").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getdata1.php?q="+str,true);
xmlhttp.send();
}
</script>
</head>
<body>
<?
$con = mysql_connect('localhost', 'unilekxy_UL', 'Unilever2011');
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("unilekxy_unilever", $con);
$skusql="SELECT packcode,concat(packcode, ' - ' , description) as description from skudata";
$resultsku=mysql_query($skusql);
$optionssku="";
while ($row=mysql_fetch_array($resultsku)) {
$sku=$row["packcode"];
$description=$row["description"];
$optionssku.="<OPTION VALUE=\"$sku\">".$description;
}
?>
<table border=1>
<tr>
<td width=393>Product</td>
<td width=200>Category</td>
<td width=150>Selling Unit</td>
<td width=150>Grouping</td>
<td width=150>Full Case QTY</td>
</tr>
</table>
<table>
<tr>
<td>
<select name="users" onchange="showUser1(this.value)" size=1>
<OPTION VALUE=0>
<?=$optionssku?>
</SELECT>
</td>
<td>
<div id="txtHint1"><b>SKU Details will be seen here</b></div>
</td>
</tr>
<tr>
<td>
<select name="users" onchange="showUser2(this.value)" size=1>
<OPTION VALUE=0>
<?=$optionssku?>
</SELECT>
</td>
<td>
<div id="txtHint2"><b>SKU Details will be seen here</b></div>
</td>
</tr>
</table>
</body>
</html>
the php page that gets called to execute the mysql is
<?php
$q=$_GET["q"];
$con = mysql_connect('localhost', 'dbuser', 'dbpass');
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
mysql_select_db("unilekxy_unilever", $con);
$sql="SELECT Category, SellingUnits,Grouping,CasesPerPallet,ShrinksPerPallet FROM skudata WHERE packcode = '".$q."'";
$result = mysql_query($sql);
while($row = mysql_fetch_array($result))
{
echo "<table border=1><tr>";
echo "<td width=200>".$row['Category']."</td>";
echo "<td width=150>".$row['SellingUnits']."</td>";
echo "<td width=150>".$row['Grouping']."</td><td width=150>";
if($row['SellingUnits']=="CS"){echo $row['CasesPerPallet'];} elseif($row['SellingUnits']=="SHR") {echo $row['ShrinksPerPallet'];}
echo "</td></tr></table>";
}
mysql_close($con);
?>
Thanks in advane for the help,
Ryan
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
您已经触及了最有价值的编程原则之一:不要重复自己 (DRY)。编程就是寻找最有效的方法来做某事。无论如何,这是重写 javascript 函数以使其更加通用的最简单方法:
现在,在每个表行中,您的选择元素变为:
用行号替换“1”。
使用 jQuery 获取最接近的 txtHint 元素将是构建代码的更好方法,但这有点超出了问题的范围。
You've touched on one of the most valuable principles of programming: Don't Repeat Yourself (DRY). Programming is all about seeking the most efficient way to do something. Anyway, here's the simplest way to rewrite your javascript function to be more generic:
Now in each of your table rows, your select element becomes:
Replacing '1' with the row number.
Using jQuery to grab the closest txtHint element would be an even better way to structure your code, but that's a little beyond the scope of the question.
这是简单的方法:
成为
并
成为
html :
成为
here's the easy way :
become
and
become
in the html :
become
您可以通过从调用者传递附加参数 Modified Function 将其设为通用函数
,请注意,函数名称已更改为
showUser
并添加了附加参数num
来标识从哪一行调用它。修改后的 HTML,请注意函数名称和附加参数 1 的更改,下一行将是 2,依此类推。
编辑:将参数名称从索引更改为 num,索引具有误导性,因为 textHint 从 1 开始。
You can make it as generic function by passing an additional argument from the caller,
Modified Function, Please Note that the function name is changed to
showUser
and added additional argumentnum
to identify from which row it is getting called.Modified HTML, Please Note the change in the function name and an additional argument 1 which will be 2 for the next row and so on.
Edit: Changed argument name from index to num, index is misleading since textHint starts from 1.
在change handler上写一个common,并在change handler中获取select元素
然后
element.parentNode.nextSibling.firstChild
会给你的 div 标签,然后使用它的 id 进行 js 元素引用并进行正确的 php 调用。这样你所有的 html 事件下标都会是相同的。您还可以编写一个以 tr 元素(代表用户)作为主体的 php 循环,然后使用上述方法挂接 javascript。这样你的 html 代码和 js 代码都会减少,你甚至不需要显式地命名它们。
Write one common on change handler, and in the change handler get select element
and then
element.parentNode.nextSibling.firstChild
would give your div tag, and then use its id for js element references and to make right php calls. This way all your html event subscripts would be same.You can also write a php loop with a tr element (represeting a user) as the body, and then use the above approach to hook up javascript. This way both your html code and js code would be reduced and you dont even have to name them explicitly.
我想我会在这里发布最终的解决方案和完整的代码。非常感谢@Amit,我使用了他的答案。也感谢所有花时间回答我问题的人,他们都非常有价值。
index.php
GetData1.php
再次感谢本网站上的每个人,非常感谢。
Thought I would post the final solution here and full code. Big Thanks to @Amit whose answer I used. Thanks also to everyone who took the time to answer my questions, all very valuable.
index.php
GetData1.php
Thanks again to everyone on this site, really appreciated.