常见的显示,循环,判断等。

解决方案 »

  1.   

    EL的循环我没有用过,
    JSTL的循环我就用过,像一些知识性的完全可以百度,就是你的问题:EL循环.
      

  2.   

    EL一般是在其它的语句中使用的,比如说在JSP页面的HTML代码中,JSTL标签中,Struts的标签中.下边的这个网址我感觉还可以,你不妨去看看.
    http://hi.baidu.com/yds_amber/blog/item/175905a10ba9f68e4610647c.html
      

  3.   

    正好手上一大把:
    <c:forEach var="data" items="${resultlist}">
    ${data.id}
    ${data.userName}
    <c:if test="${data.valid}"可</c:if>
    <c:if test="${not data.valid}">否</c:if>
    ${data.createdate}
    </c:forEach>
      

  4.   

    没见过el的循环,只见过jstl的循环.
      

  5.   

    Tomcat\webapps\jsp-examples\jsp2\el
    看一下这个目录就都明白了
      

  6.   

    EL有循环吗??我要去查一下...JSTL有标签可以遍历集合的<c:foreach></c:foreach>..
      

  7.   

    Expression language,表达式语言,应该是没有循环的,它只是为了输出..
      

  8.   


    哦!那就说说jstl的语法吧!
      

  9.   

    很多东西首先要自己去学,然后遇到问题了可以问别人.如果你都没学过就叫别人教,对我来说,我不愿意浪费这个时间,真的感觉不是三言两语可以说得了.
    一般情况我都是先搜索教程,比如百度:JSTL教程,AJAX教程.先看书,看看到底讲些什么,然后里某个地方不明白了再来问人.
      

  10.   

    我们已经知道el是jsp-2.0规范的一部分,tomcat-5.x版本以上都已经能够支持jsp-2.0规范,但在更低版本的tomcat和webphere,weblogic中还是无法使用这一便捷方式。其实我们也可以选择在jsp中禁止使用el表达式,使用jsp指令(directive)可以对禁用某一个jsp中的el表达式。禁用之后的el表达式会以原样显示出来,如下图所示。
    为了对照,我们还在13-01下放了一个可以正常使用el表达式的例子,运行效果如下图显示。
    在13-01/index.jsp中禁用el表达式,是使用了isELIgnore="true"这样一条jsp指令(directive),请注意大小写。<%@ page isELIgnored="true" %>
    <%
        pageContext.setAttribute("hello", "Hello World");
    %>${hello}
    还有一种批量禁用el的方法,我们可以在WEB-INF/web.xml中使用jsp-property-group标签批量禁用el,我们在13-02/WEB-INF/web.xml中进行如下配置。<?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns="http://java.sun.com/xml/ns/j2ee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
        version="2.4">    <jsp-config>
            <jsp-property-group>
                <url-pattern>*.jsp</url-pattern>
                <el-ignored>true</el-ignored>
            </jsp-property-group>
        </jsp-config></web-app>
    这样就会禁用所有以.jsp后缀的请求中的el表达式,使用这种方式需要注意两点。jsp-property-group标签是jsp-2.0中新增功能,如果你使用低版本的web.xml(2.3或以下)就不能使用这个标签了。设置jsp-config会影响jsp生成servlet的过程,如果程序修改时已经有jsp转换成servlet并缓存在work目录下,那么修改后需要先清除缓存,才能看到效果。实际上还有第三种方法可以禁用掉所有jsp中的el表达式,那就是把web.xml定义为2.3版。<?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE web-app PUBLIC
        "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
        "http://java.sun.com/dtd/web-app_2_3.dtd">
    <web-app>
    </web-app>
    这个就是13-03/WEB-INF/web.xml的定义,定义了web-app的版本号是2.3,这样一来所有的jsp都无法使用el表达式了,因为el表达式是2.4版才开始支持的功能。注意
    说了以上三种禁用el表达式的方法,不是希望大家抛弃el表达式,相反是希望大家在自己编写el时出现问题时,先去考虑是否有人在这三个地方做了设置造成el表达式的失效。建议大家多多使用el表达式,少用一些jsp中的scriptlet代码。
    ==================================================================作用域使用el的时候,默认会以一定顺序搜索四个作用域,将最先找到的变量值显示出来。
    如果我们有${username}这样一个正则表达式,它回去依次调用pageContext.getAttribute("username") -> request.getAttribute("username") -> session.getAttribute("username") -> application.getAttribute("username"),只要找到某一个不为空的值就立刻返回。这样的确方便我们的操作,但是随之也出现了另外一个问题,如果pageContext和request中有同名变量,但是我想取得request中的变量该如何是好呢?这就需要为el表达式引入作用域的概念了。${pageScope.username}${requestScope.username}
    我们可以直接访问13-04这个应用,看看el表达式支持的所有对象。
    下面我们分别对每个作用域对象进行讲解。表 13.1. el中的作用域el中的作用域 对应关系 
    pageContext(1) 当前页的pageContext对象 
    pageScope 把page作用域中的数据映射为一个map对象 
    requestScope(2) 把request作用域中的数据映射为一个map对象 
    sessionScope 把session作用域中的数据映射为一个map对象 
    applicationScope 把application作用域中的数据映射为一个map对象 
    param 对应request.getParameter() 
    paramValues(3) 对应request.getParameterValues() 
    header(4) 对应request.getHeader() 
    headerValues 对应request.getHeaderValues() 
    cookie(5) 对应request.getCookies() 
    initParam(6) 对应ServletContext.getInitParamter() 
    (1)
     例子中的${pageContext.request.contextPath}返回的是request.getContextPath()的值,在此例中就是/13-04,我们经常使用这个来拼接jsp中的绝对路径。这里的${pageContext.request.contextPath}是一种特殊用法,不能使用${request.contextPath}的形式替代。
     
    (2)
     pageScope, requestScope, sessionScope, appliationScope都可以看作是Map型变量,调用其中的数据可以使用${pageScope.name}或${pageScope["name"]}的形式,这两种写法是等价的。在某些情况下只能使用${pageScope["content-type"]},这里不能写成${pageScope.content-type},jsp无法解析连字符(-)会出现错误。
     
    (3)
     需要注意的是${paramValues.name}得到的是一个字符串数组,如果需要获得其中某个值,还需要使用${paramValues.name[0]}指定数组中的索引。这与下面的${headerValues.name}是相似的。
     
    (4)
     ${header.name}会取得http请求中的header参数,现实工作中很少用到这里的数据。例子中使用Host是指请求访问的主机地址,包括ip和端口号。而Referer比较有趣,如果用户通过超链接跳转过来的,Referer会保存上次访问页面的地址,我们就可以通过它来统计哪些用户是从哪里转来的了。
     
    (5)
     ${cookie.name}将获得对应cookie的对象,比如我们用jsp将一段cookie发送给客户端。Cookie cookie = new Cookie("username", "Username in cookie");
    response.addCookie(cookie);
    创建一个名称为username,值为"Username in cookie"的Cookie对象,然后发送给客户端。然后我们就可以使用${cookie.username}获得这个cookie了,${cookie.username.name}获得cookie名称,${cookie.username.value}获得cookie值。
     
    (6)
     ServletContext.getInitParamter()指的应用的初始变量,这些变量都是定义在web.xml中的。<context-param>
        <param-name>username</param-name>
        <param-value>username with context param</param-value>
    </context-param>
    ${initParam.username}就会得到这里的变量值。
     以上都是死记硬背的东西,建议实际用到的时候翻看一下就好了,演示代码都放在13-04下,为了获得param和cookie还要点击一下最下边的连接才可以。