JavaScript請求后臺數(shù)據(jù)的常用方法匯總
更新時間:2023年08月09日 17:21:27 作者:梁云亮
這篇文章主要介紹了JavaScript請求后臺數(shù)據(jù)的幾種常用方式,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
0、所用到的服務(wù)器端的代碼
@WebServlet(urlPatterns = "/demoServlet")
public class DemoServlet extends HttpServlet {
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String data = request.getParameter("data");
response.getWriter().write("{'data':'"+data+"'}");
System.out.println("doPost:"+data);
}
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String data = request.getParameter("data");
response.getWriter().write("{'data':'"+data+"'}");
System.out.println("doGet:"+data);
}
}1、window.location.href
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
<title>JavaScript請求后臺</title>
<script type="text/javascript">
function fun() {
window.location.href="${pageContext.request.contextPath}/demoServlet?data=haha";
}
</script>
</head>
<body>
<button onclick="fun()">請求</button>
</body>
</html>2、window.open()
把js中的值傳到后臺,區(qū)別是后臺請求后臺之后,默認(rèn)會打開新的瀏覽器窗口。
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
<title>JavaScript請求后臺</title>
<script type="text/javascript">
function fun() {
// window.open("${pageContext.request.contextPath}/demoServlet?data=haha"); //打開新的窗口
window.open("${pageContext.request.contextPath}/demoServlet?data=haha","_self"); //在原窗口中撕開
}
</script>
</head>
<body>
<button onclick="fun()">請求</button>
</body>
</html>3、.submit()方法提交表單
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
<title>JavaScript請求后臺</title>
<script type="text/javascript">
function fun() {
var form = document.forms["form1"];
form.action="${pageContext.request.contextPath}/demoServlet";
form.method="GET";
form.submit();
}
</script>
</head>
<body>
<form name="form1">
<input type="text" name="data">
</form>
<button onclick="fun()">請求</button>
</body>
</html>4、.submit()方法提交表單
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
<title>JavaScript請求后臺</title>
<script type="text/javascript">
function fun() {
var form = document.createElement("form");
//form.action="${pageContext.request.contextPath}/demoServlet?data=haha"; //這種方式不能將數(shù)據(jù)傳遞到后臺
form.action="${pageContext.request.contextPath}/demoServlet";
var input = document.createElement("input");
input.name="data";
input.value= "haha";
form.appendChild(input);
form.method="GET";
document.body.appendChild(form);
form.submit();
}
</script>
</head>
<body>
<button onclick="fun()">請求</button>
</body>
</html>5、自定義AJAX
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
<title>JavaScript請求后臺</title>
<script type="text/javascript">
function fun() {
var xhr;
if (window.XMLHttpRequest) {
xhr = new window.XMLHttpRequest;
} else {
xhr = new ActiveXObject("Microsoft.XMLHTTP");
}
xhr.onreadystatechange = success;
var url="${pageContext.request.contextPath}/demoServlet?data=haha";
xhr.open("POST", url, false);
xhr.send();
function success() {
if (xhr.readyState == 4 && xhr.status == 200) { //回傳成功
console.info(xhr.responseText);
return true;
} else {
return false;
}
}
}
</script>
</head>
<body>
<button onclick="fun()">請求</button>
</body>
</html>6、使用JQuery
請參看博客:JQuery AJAX
到此這篇關(guān)于JavaScript請求后臺數(shù)據(jù)的幾種常用方式的文章就介紹到這了,更多相關(guān)js請求后臺數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
調(diào)試Node.JS的輔助工具(NodeWatcher)
Node.JS調(diào)試貌似比較麻煩,每次改完了要重啟一下Node進(jìn)程.GOOGLE上有個NPM模塊,可以監(jiān)控JS文件的更改,然后自動重啟Node.但我下載后在windows里運行報錯2012-01-01

