2.1. HelloWorld之jquery
說明:
(1) 這是nutz與html進行相互通訊。Html網頁中使用了jquery
??? (2) netbeans 6.9.1版開發,nutz 1.a.31,jquery 1.3.2
??? (3) 功能:打開new.html網頁,輸入姓名、年齡,按提交,nutz收到new.html發出的信息,然后增加點信息,再返回給new.html。最后new.html顯示返回值
??? (4)這只是一個示例,返回的json還是字符串,如果要直接返回json對象,請看#json視圖。
????
2.1.1. 步驟1 建立新工程HelloNutZ1,并下載jquery1.3.2.js
下載好的jquery 1.3.2 ,放在js文件夾中。Js文件夾位于 WEB-Pages 下。
2.1.2. 步驟2 從官方下載Nutz,并導入新建工程中
方法:選中Libraries,按右鍵,選ADD JAR/Fold,選中解壓后的nutz
2.1.3. 步驟3 配置WEB.xml
下面是完整代碼:新增的僅含有filter
2.1.4. 步驟四 建個網頁,名字任取,如:new.html
代碼說明:
??? 1 特別強調,要把jquery包導入。
??? 2 用了ajax,post,get三種方式與nutz交互
完整代碼:
2.1.5. 建立MainModule.java
說明:
(1) @ Modules ----指明了子模塊為HelloWorld,可以有多個,要用逗號分開
(2) @Fail("json") ---指明了失敗格式為json
完整源代碼:
2.1.6. 建立HelloWorld.java
說明:
(1) 該類必須在MainModule注釋中出現,否則不起作用
(2) @Ok("json")----指明所有入口函數返回形式為json
(3) @At("/yousay")----指明隨后的函數 負責響應網頁或用戶發出的請求。請求格式為:基網址/yousay。例:http://localhost:8084/HelloNutz1/yousay
完整源代碼:
運行后的效果圖
說明:
(1) 這是nutz與html進行相互通訊。Html網頁中使用了jquery
??? (2) netbeans 6.9.1版開發,nutz 1.a.31,jquery 1.3.2
??? (3) 功能:打開new.html網頁,輸入姓名、年齡,按提交,nutz收到new.html發出的信息,然后增加點信息,再返回給new.html。最后new.html顯示返回值
??? (4)這只是一個示例,返回的json還是字符串,如果要直接返回json對象,請看#json視圖。
????
2.1.1. 步驟1 建立新工程HelloNutZ1,并下載jquery1.3.2.js
下載好的jquery 1.3.2 ,放在js文件夾中。Js文件夾位于 WEB-Pages 下。
2.1.2. 步驟2 從官方下載Nutz,并導入新建工程中
方法:選中Libraries,按右鍵,選ADD JAR/Fold,選中解壓后的nutz
2.1.3. 步驟3 配置WEB.xml
下面是完整代碼:新增的僅含有filter
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <session-config> <session-timeout> 30 </session-timeout> </session-config> <filter> <filter-name>nutz</filter-name> <filter-class>org.nutz.mvc.NutFilter</filter-class> <init-param> <param-name>modules</param-name> <param-value>MainModule</param-value> </init-param> </filter> <filter-mapping> <filter-name>nutz</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app>
2.1.4. 步驟四 建個網頁,名字任取,如:new.html
代碼說明:
??? 1 特別強調,要把jquery包導入。
??? 2 用了ajax,post,get三種方式與nutz交互
完整代碼:
<html> <head> <title></title> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <link type="text/css" href="./js/css/ui-lightness/jquery-ui-1.8.4.custom.css" rel="stylesheet" /> <script type="text/javascript" src="./js/jquery-1.3.2.js"></script> <script type="text/javascript"> $(document).ready(function () { $('#send_ajax').click(function (){ var params=$('input').serialize(); //序列化表單的值 $.ajax({ url:'yousay', //后臺處理程序 type:'post', //數據發送方式 dataType:'json', //接受數據格式 data:params, //要傳遞的數據 success:update_page //回傳函數(這里是函數名) }); }); //$.post()方式: $('#test_post').click(function (){ $.post( 'yousay', { username:$('#input1').val(), age:$('#input2').val() }, function (data) //回傳函數 { var myjson=''; eval('myjson=' + data + ';'); eval('myjson=' + myjson + ';'); $('#result').html("姓名:" + myjson.username + "<br/>年齡" + myjson['age']); } ); }); //$.get()方式: $('#test_get').click(function () { $.get( 'yousay', { username:$("#input1").val(), age:$("#input2").val() }, function(data) //回傳函數 { var myjson=''; eval("myjson=" + data + ";"); eval('myjson=' + myjson + ';'); $("#result").html(myjson.age); } ); }); }); function update_page (json) //回傳函數實體,參數為XMLhttpRequest.responseText { eval("json=" + json + ";"); var str="姓名:"+json.username+"<br />"; str+="年齡:"+json.age+"<br />"; str+="追加測試:"+json.append; $("#result").html(str); } </script> </head> <body> <div id="result" style="background:orange;border:1px solid red;width:300px;height:200px;"></div> <form id="formtest" action="" method="post"> <p><span>輸入姓名:</span><input type="text" name="username" id="input1" /></p> <p><span>輸入年齡:</span><input type="text" name="age" id="input2" /></p> </form> <button id="send_ajax">提交</button> <button id="test_post">POST提交</button> <button id="test_get">GET提交</button> </body> </html>
2.1.5. 建立MainModule.java
說明:
(1) @ Modules ----指明了子模塊為HelloWorld,可以有多個,要用逗號分開
(2) @Fail("json") ---指明了失敗格式為json
完整源代碼:
import org.nutz.mvc.adaptor.PairAdaptor; import org.nutz.mvc.annotation.*; import org.nutz.mvc.ioc.provider.JsonIocProvider; @Modules({HelloWorld.class}) @Fail("json") public class MainModule {}
2.1.6. 建立HelloWorld.java
說明:
(1) 該類必須在MainModule注釋中出現,否則不起作用
(2) @Ok("json")----指明所有入口函數返回形式為json
(3) @At("/yousay")----指明隨后的函數 負責響應網頁或用戶發出的請求。請求格式為:基網址/yousay。例:http://localhost:8084/HelloNutz1/yousay
完整源代碼:
import org.nutz.lang.Strings; import org.nutz.mvc.annotation.At; import org.nutz.mvc.annotation.Ok; import org.nutz.mvc.annotation.Param; @Ok("json") public class HelloWorld { @At public String say() { return "Hello world"; } @At("/yousay") public String sayMore(@Param("username") String username, @Param("age") String age ) { if (Strings.isBlank(username)) return say(); String str="{'username':'" + username +"','age':'"+age+"','append':'nuzamAppend'}"; return str; } }
運行后的效果圖

更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
