zoukankan      html  css  js  c++  java
  • js获取url(request)中的参数

    index.htm?参数1=数值1&参数2=数值2&参数3=数据3&参数4=数值4&......

    静态html文件js读取url参数,根据获取html的参数值控制html页面输出。

    一、字符串分割分析法。

    这里是一个获取URL带REQUESTRING参数的JAVASCRIPT客户端解决方案。

    相当于asp的request.querystringPHP的$_GETjsp的request.getParameter

    //var USERCODE="<%=request.getParameter("USERCODE")%>";

    //以上是用request.getParameter在浏览器端获取参数值, 也可以是用该方法在服务器端获取参数方法

    函数:

    <Script language="javascript">

    function GetRequest() {

       var url = location.search; //获取url中含"?"符后的字串

       var theRequest = new Object();

       if (url.indexOf("?") != -1) {

          var str = url.substr(1);

          strs = str.split("&");

          for(var i = 0; i < strs.length; i ++) {

             theRequest[strs[i].split("=")[0]]=unescape(strs[i].split("=")[1]);

          }

       }

       return theRequest;

    }

    </Script>

    然后我们通过调用此函数获取对应参数值:

    <Script language="javascript">

    var Request = new Object();

    Request = GetRequest();

    var 参数1,参数2,参数3,参数N;

    参数1 = Request['参数1'];

    参数2 = Request['参数2'];

    参数3 = Request['参数3'];

    参数N = Request['参数N'];

    </Script>

    以此获取url串中所带的同名参数

    二、正则分析法。

    function GetQueryString(name) {

       var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)","i");

       var r = window.location.search.substr(1).match(reg);

       if (r!=null) return unescape(r[2]); return null;

    }

    alert(GetQueryString("参数名1"));

    alert(GetQueryString("参数名2"));

    alert(GetQueryString("参数名3"));

    三、java举例如下:

    1、
    <%@ page language="java" import="java.util.*,com.servlet.bean" pageEncoding="UTF-8"%>
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <body>
        <script type="text/javascript">         
           <%
            ArrayList list = (ArrayList)request.getAttribute("list");
            for(int i=0;i<list.size();i++){
                bean Bean = (bean)list.get(i);
         %>
              var name = '<%=Bean.getName()%>' //这里是从request获取参数,赋值给name这个变量
         <%     
            }
         %>
        </script>
      </body>
    </html>
    2、在servlet服务端的代码如下:
    package com.servlet;

    import java.io.IOException;
    import java.io.PrintWriter;
    import java.util.ArrayList;

    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;

    public class servlet extends HttpServlet {
        public servlet() {
            super();
        }

        /**
         * Destruction of the servlet. <br>
         */
        public void destroy() {
            super.destroy(); // Just puts "destroy" string in log
            // Put your code here
        }

        public void doGet(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            bean Bean = new bean();
            Bean.setName("liubin");
            Bean.setPwd("123");
            
            bean Bean2 = new bean();
            Bean2.setName("aaa");
            Bean2.setPwd("456");
            
            bean Bean3 = new bean();
            Bean3.setName("bbb");
            Bean3.setPwd("789");
            
            ArrayList list = new ArrayList();
            list.add(Bean);
            list.add(Bean2);
            list.add(Bean3);
            
            request.setAttribute("list", list);
            
            request.getRequestDispatcher("../index.jsp").forward(request, response);
        }
        public void doPost(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            doGet(request ,response);
        }
        public void init() throws ServletException {
            // Put your code here
        }
    }

    四、

    javascript可以通过window.navigator来进行判断。不同的浏览器navigator对象里的名称是不同的:
    window.navigator.userAgent  记录浏览器信息以及操作系统信息。

    1.取变量值
        var a = '<%=request.getAttribute("aaa");%>' ;
    2.也可以将这个值放在页面上.再取出来.
        <input type="hidden" value="<%=request.getAttribute("aaa");%>" id="aaa"/>
        var a = document.getElementById('aaa').value ;

    (注):对于对象,我推荐使用第二种方法.这样可以在页面中不IMPORT JAVA类..更符合现在编程
        eg:
        <input type="hidden" value="${student.name}" id="stuName"/>
        var stuName = $('stuName').value ; // prototype.js新功能,简写.

  • 相关阅读:
    Windows各个文件夹介绍
    Zabbix使用外部命令fping处理ICMP ping的请求
    QT 样式表实例
    QT 样式表基础知识
    cocos2d-js入门一
    try throw catch typeid
    cocos2d-x入门三 分层设计框架
    cocos2d-x入门二 helloworld实例运行与创建
    cocos2d-x入门一
    批量操作QT UI中的控件
  • 原文地址:https://www.cnblogs.com/appcx/p/6962130.html
Copyright © 2011-2022 走看看