Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 成人精品免费视频,www.99精品视频在线播放,高清欧美日本视频免费观看

          整合營銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          javascript中用reduce高階函數(shù)組裝查詢

          javascript中用reduce高階函數(shù)組裝查詢表單分隔字符數(shù)據(jù)

          詢表單,一次輸入多個(gè)參數(shù),一般是從網(wǎng)站或者excel中復(fù)制,要求前端用空格、逗號或者回車切割參數(shù),傳給后端。

          這個(gè)需求也很常見,之前是先用 split 分隔成數(shù)組,再用 map 遍歷去掉首尾空格,最后再用 filter 來過濾下空值,但是這樣需要遍歷兩次,如果想只用一個(gè) map 實(shí)現(xiàn),那還得額外定義個(gè)變量來儲存數(shù)據(jù)。

          其實(shí)像這種組裝數(shù)據(jù)直接用 reduce 就能完美解決,一般有的后端要求用戶沒填的參數(shù)就不傳,不需要傳個(gè)空字符串或者空數(shù)組這種,那我們r(jià)educe的初始值直接給成 undefined 就不會(huì)傳給后端了,不過注意 push 的時(shí)候就要額外判斷下了,否則會(huì)報(bào)錯(cuò)。

          用回車、中英文逗號或空格分隔字符正則:/\n+|,|,|\s+/g

          利用 reduce 過濾組裝數(shù)據(jù) demo:

          let a=[' ', '1  ', 'zhou', '  ']
          let b=a.reduce((m, n)=> {
            if (n) {
              const txt=n.trim()
              if (txt) m.push(txt)
            }
            return m
          }, [])
          console.log(b) // ['1', 'zhou']

          項(xiàng)目中使用完整示例代碼:

          我們在瀏覽網(wǎng)頁的時(shí)候,經(jīng)常需要向服務(wù)器提交信息,并讓后臺程序處理。瀏覽器中使用 GET 和 POST 方法向服務(wù)器提交數(shù)據(jù)。

          GET 方法

          GET方法將請求的編碼信息添加在網(wǎng)址后面,網(wǎng)址與編碼信息通過"?"號分隔。如下所示:

          http://www.runoob.com/hello?key1=value1&key2=value2

          GET方法是瀏覽器默認(rèn)傳遞參數(shù)的方法,一些敏感信息,如密碼等建議不使用GET方法。

          用get時(shí),傳輸數(shù)據(jù)的大小有限制 (注意不是參數(shù)的個(gè)數(shù)有限制),最大為1024字節(jié)。

          POST 方法

          一些敏感信息,如密碼等我們可以通過POST方法傳遞,POST提交數(shù)據(jù)是隱式的。

          POST提交數(shù)據(jù)是不可見的,GET是通過在url里面?zhèn)鬟f的(可以看一下你瀏覽器的地址欄)。

          JSP使用getParameter()來獲得傳遞的參數(shù),getInputStream()方法用來處理客戶端的二進(jìn)制數(shù)據(jù)流的請求。

          JSP 讀取表單數(shù)據(jù)

          • getParameter(): 使用 request.getParameter() 方法來獲取表單參數(shù)的值。

          • getParameterValues(): 獲得如checkbox類(名字相同,但值有多個(gè))的數(shù)據(jù)。 接收數(shù)組變量 ,如checkbox類型

          • getParameterNames():該方法可以取得所有變量的名稱,該方法返回一個(gè)Emumeration。

          • getInputStream():調(diào)用此方法來讀取來自客戶端的二進(jìn)制數(shù)據(jù)流。



          使用URL的 GET 方法實(shí)例

          以下是一個(gè)簡單的URL,并使用GET方法來傳遞URL中的參數(shù):

          http://localhost:8080/testjsp/main.jsp?name=菜鳥教程&url=http://ww.runoob.com

          testjsp 為項(xiàng)目地址。

          以下是 main.jsp 文件的JSP程序用于處理客戶端提交的表單數(shù)據(jù),我們使用getParameter()方法來獲取提交的數(shù)據(jù):

          <%@ page language="java" contentType="text/html; charset=UTF-8"

          pageEncoding="UTF-8"%>

          <%@ page import="java.io.*,java.util.*" %>

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>菜鳥教程(runoob.com)</title>

          </head>

          <body>

          <h1>使用 GET 方法讀取數(shù)據(jù)</h1>

          <ul>

          <li><p><b>站點(diǎn)名:</b>

          <%=request.getParameter("name")%>

          </p></li>

          <li><p><b>網(wǎng)址:</b>

          <%=request.getParameter("url")%>

          </p></li>

          </ul>

          </body>

          </html>

          接下來我們通過瀏覽器訪問 http://localhost:8080/testjsp/main.jsp?name=菜鳥教程&url=http://ww.runoob.com 輸出結(jié)果如下所示:

          使用表單的 GET 方法實(shí)例

          以下是一個(gè)簡單的 HTML 表單,該表單通過GET方法將客戶端數(shù)據(jù)提交 到 main.jsp 文件中:

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>菜鳥教程(runoob.com)</title>

          </head>

          <body>

          <form action="main.jsp" method="GET">

          站點(diǎn)名: <input type="text" name="name">

          <br />

          網(wǎng)址: <input type="text" name="url" />

          <input type="submit" value="提交" />

          </form>

          </body>

          </html>

          將以上HTML代碼保存到test.htm文件中。 將該文件放置于當(dāng)前jsp項(xiàng)目的 WebContent 目錄下(與 main.jsp 同一個(gè)目錄)。

          通過訪問 http://localhost:8080/testjsp/test.html 提交表單數(shù)據(jù)到 main.jsp 文件,演示 Gif 圖如下所示:

          在 "站點(diǎn)名" 與 "網(wǎng)址" 兩個(gè)表單中填入信息,并點(diǎn)擊 "提交" 按鈕,它將輸出結(jié)果。

          使用表單的 POST 方法實(shí)例

          接下來讓我們使用POST方法來傳遞表單數(shù)據(jù),修改main.jsp與Hello.htm文件代碼,如下所示:

          main.jsp文件代碼:

          <%@ page language="java" contentType="text/html; charset=UTF-8"

          pageEncoding="UTF-8"%>

          <%@ page import="java.io.*,java.util.*" %>

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>菜鳥教程(runoob.com)</title>

          </head>

          <body>

          <h1>使用 POST 方法讀取數(shù)據(jù)</h1>

          <ul>

          <li><p><b>站點(diǎn)名:</b>

          <%

          // 解決中文亂碼的問題

          String name=new String((request.getParameter("name")).getBytes("ISO-8859-1"),"UTF-8");

          %>

          <%=name%>

          </p></li>

          <li><p><b>網(wǎng)址:</b>

          <%=request.getParameter("url")%>

          </p></li>

          </ul>

          </body>

          </html>

          代碼中我們使用 new String((request.getParameter("name")).getBytes("ISO-8859-1"),"UTF-8")來轉(zhuǎn)換編碼,防止中文亂碼的發(fā)生。

          以下是test.htm修改后的代碼:

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>菜鳥教程(runoob.com)</title>

          </head>

          <body>

          <form action="main.jsp" method="POST">

          站點(diǎn)名: <input type="text" name="name">

          <br />

          網(wǎng)址: <input type="text" name="url" />

          <input type="submit" value="提交" />

          </form>

          </body>

          </html>

          通過訪問 http://localhost:8080/testjsp/test.html 提交表單數(shù)據(jù)到 main.jsp 文件,演示 Gif 圖如下所示:

          傳遞 Checkbox 數(shù)據(jù)到JSP程序

          復(fù)選框 checkbox 可以傳遞一個(gè)甚至多個(gè)數(shù)據(jù)。

          以下是一個(gè)簡單的HTML代碼,并將代碼保存在test.htm文件中:

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>菜鳥教程(runoob.com)</title>

          </head>

          <body>

          <form action="main.jsp" method="POST" target="_blank">

          <input type="checkbox" name="google" checked="checked" /> Google

          <input type="checkbox" name="runoob" /> 菜鳥教程

          <input type="checkbox" name="taobao" checked="checked" />

          淘寶

          <input type="submit" value="選擇網(wǎng)站" />

          </form>

          </body>

          </html>

          以上代碼在瀏覽器訪問如下所示:

          以下為main.jsp文件代碼,用于處理復(fù)選框數(shù)據(jù):

          <%@ page language="java" contentType="text/html; charset=UTF-8"

          pageEncoding="UTF-8"%>

          <%@ page import="java.io.*,java.util.*" %>

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>菜鳥教程(runoob.com)</title>

          </head>

          <body>

          <h1>從復(fù)選框中讀取數(shù)據(jù)</h1>

          <ul>

          <li><p><b>Google 是否選中:</b>

          <%=request.getParameter("google")%>

          </p></li>

          <li><p><b>菜鳥教程是否選中:</b>

          <%=request.getParameter("runoob")%>

          </p></li>

          <li><p><b>淘寶是否選中:</b>

          <%=request.getParameter("taobao")%>

          </p></li>

          </ul>

          </body>

          </html>

          通過訪問 http://localhost:8080/testjsp/test.html 提交表單數(shù)據(jù)到 main.jsp 文件,演示 Gif 圖如下所示:

          讀取所有表單參數(shù)

          以下我們將使用 HttpServletRequestgetParameterNames() 來讀取所有表單參數(shù),該方法可以取得所有變量的名稱,該方法返回一個(gè)枚舉。

          一旦我們有了一個(gè) Enumeration(枚舉),我們就可以調(diào)用 hasMoreElements() 方法來確定是否還有元素,以及使用nextElement()方法來獲得每個(gè)參數(shù)的名稱。

          <%@ page language="java" contentType="text/html; charset=UTF-8"

          pageEncoding="UTF-8"%>

          <%@ page import="java.io.*,java.util.*" %>

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>菜鳥教程(runoob.com)</title>

          </head>

          <body>

          <h1>讀取所有表單參數(shù)</h1>

          <table width="100%" border="1" align="center">

          <tr bgcolor="#949494">

          <th>參數(shù)名</th><th>參數(shù)值</th>

          </tr>

          <%

          Enumeration paramNames=request.getParameterNames();

          while(paramNames.hasMoreElements()) {

          String paramName=(String)paramNames.nextElement();

          out.print("<tr><td>" + paramName + "</td>\n");

          String paramValue=request.getParameter(paramName);

          out.println("<td> " + paramValue + "</td></tr>\n");

          }

          %>

          </table>

          </body>

          </html>

          以下是test.htm文件的內(nèi)容:

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="utf-8">

          <title>菜鳥教程(runoob.com)</title>

          </head>

          <body>

          <form action="main.jsp" method="POST" target="_blank">

          <input type="checkbox" name="google" checked="checked" /> Google

          <input type="checkbox" name="runoob" /> 菜鳥教程

          <input type="checkbox" name="taobao" checked="checked" />

          淘寶

          <input type="submit" value="選擇網(wǎng)站" />

          </form>

          </body>

          </html>

          現(xiàn)在我們通過瀏覽器訪問 test.htm 文件提交數(shù)據(jù),輸出結(jié)果如下:

          通過訪問 http://localhost:8080/testjsp/test.html 提交表單數(shù)據(jù)到 main.jsp 文件,演示 Gif 圖如下所示:

          你可以嘗試使用以上的JSP代碼讀取其它對象,如文本框,單選按鈕或下拉框等等其他形式的數(shù)據(jù)。

          如您還有不明白的可以在下面與我留言或是與我探討QQ群308855039,我們一起飛!

          個(gè)表單的form標(biāo)簽是必不可少的,所有的表單元素都應(yīng)該被他包含。一個(gè)頁面可能有多個(gè)表單,就需要對每個(gè)表單的區(qū)域進(jìn)行分組,防止表單信息混雜。

          目標(biāo)

          1. 表單的完整結(jié)構(gòu)?
          2. 表單內(nèi)如何進(jìn)行元素分組?

          表單

          可以在一個(gè)網(wǎng)頁中收集用戶的數(shù)據(jù),比如填寫用戶注冊數(shù)據(jù)、留言板、評論等內(nèi)容。

          Form標(biāo)簽

          一個(gè)表單的form標(biāo)簽是必不可少的,所有的表單元素都應(yīng)該被他包含。

          <form >
          	<input type="text" />			
          </form>
          

          一個(gè)網(wǎng)頁可能會(huì)有多個(gè)表單,就需要聲明每個(gè)表單的區(qū)域,防止表單信息混雜。

          以下就是兩個(gè)表單,他們之間的表單元素就會(huì)跟隨自己的表單。

          兩個(gè)表單

          分組

          有時(shí)候,表單內(nèi)的元素過多,就需要將他們進(jìn)行分類。

          fieldset標(biāo)簽可以將表單內(nèi)的相關(guān)元素分組。

          legend標(biāo)簽是為 fieldset元素定義標(biāo)題。

          <fieldset >
          	<legend>學(xué)生信息</legend>
          	姓名:<input type="text" /><br>
          	班級:<input type="text" /><br>			
          </fieldset>
          

          分組

          分組完成

          總結(jié)

          思維導(dǎo)圖


          主站蜘蛛池模板: 日本在线观看一区二区三区| 一级毛片完整版免费播放一区| 无码少妇丰满熟妇一区二区| 丰满岳乱妇一区二区三区| 97久久精品一区二区三区| 不卡一区二区在线| 精品免费国产一区二区三区| 亚洲视频一区网站| 精品无码日韩一区二区三区不卡| 一区在线免费观看| 精品视频一区在线观看| 日韩AV片无码一区二区不卡| 一区二区精品在线| 无码囯产精品一区二区免费 | 久久精品免费一区二区喷潮 | 日本一区二区三区不卡视频| 精品一区二区久久久久久久网站| 爆乳熟妇一区二区三区霸乳| 国产中文字幕一区| 日韩精品午夜视频一区二区三区| 日本精品无码一区二区三区久久久| 亚洲av不卡一区二区三区| 无码av免费一区二区三区| 国产激情з∠视频一区二区| 日本亚洲成高清一区二区三区| 亚洲无线码一区二区三区| 手机看片一区二区| 亚洲AV午夜福利精品一区二区 | 亚洲av成人一区二区三区在线播放| 色狠狠一区二区三区香蕉| 亚洲国产精品一区| 91精品福利一区二区| 韩国福利视频一区二区| 精品一区二区三区在线播放 | 精品人妻AV一区二区三区| 韩国福利一区二区美女视频| 中文字幕AV无码一区二区三区| 无码夜色一区二区三区| 日本人真淫视频一区二区三区| 久久免费视频一区| 无码一区二区三区老色鬼|