如何在jsp中使用javascript

时间:2013-12-05 03:28:01

标签: javascript jsp

我想调用一个返回值的javascript函数,然后将该值放在if语句中。 HTML中有两个单选按钮,javascript会检查单击哪一个。之后,JSP将其与“客户”或“公司”进行比较,并执行相应的SQL查询。

使用Javascript:

 function corc{
    var value;

    if(document.getElementById('cust').checked){
           value='customer';
            return value;
    }else if(document.getElmentById('comp').checked){
           value='company';
           return value;
    }
 }

JSP:

if(%>corc();<%.equals("customer")){
             String sqlqueryCommand = "SELECT * from customer where login='" + v1 + "' and password='" + v2     + "'";
}else if (%>corc();<%.equals("company")){
             String sqlqueryCommand = "SELECT * from company where login='" + v1 + "' and password='" + v2     + "'";
}

2 个答案:

答案 0 :(得分:8)

  • 你不能在JSP的if语句中调用JavaScript函数,因为JSP是在服务器端执行的,而JavaScript是在客户端执行的。

  • 单击单选按钮时,必须使用onclick事件触发事件,您可以调用函数corc()

  • 不要在JSP中编写scriptlet,因为scriptlet不应该在JSP中使用超过十年。学习JSP ELJSTL,并使用servlet获取Java代码。 How to avoid Java Code in JSP-Files?

JSP代码:

.......
........
//use <form> to submit values to servlet

 <input type="radio" name="radio1" onclick="handleClick(this.id);" id="customerId" />
 <input type="radio" name="radio1" onclick="handleClick(this.id);" id="companyId" />
......
.......
//use hidden field to assign table value i.e. "customer" or "company".
 <input type="hidden" name="tableValue" id="tableTextId" />  
//</form> closing form tag

onclick事件我分配了handleClick函数并传递了this.id,参数this.id用于传递点击的单选按钮的id属性。

JavaScript代码:

<script type="text/javascript">
  function handleClick(clickedId)
  {
     if(clickedId == "customerId")
       document.getElementById('tableTextId').value = "customer";
     else
       document.getElementById('tableTextId').value = "company";
  }
</script>
  • 当您提交表单然后在servlet中,您可以获得隐藏字段的值。
  

String tableName = request.getParameter(“tableValue”); //传递隐藏字段的名称,即tableValue

  • 您可以进一步将此tableName传递给查询。

相关链接

答案 1 :(得分:-1)

<input type="button" class="btn btn-danger" value="Delete" d=""+rs.getString(1)+"/>
<script type="text/javascript">$(document).ready(function(){
    $(":Delete").click(function(){
        alert("Do you want to Delete this token : "+this.id);
    });
});
</script>