<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-34  評論-1965  文章-0  trackbacks-0

    在當今——Web 2.0概念鋪天蓋地的Internet環境下,簡易的AJAX集成對于一個成功的WEB框架來說是不可或缺的。因此,Struts 2其中的一個重要的功能(Feature)就是“First-class AJAX support - Add interactivity and flexibility with AJAX tags that look and feel just like standard Struts tags(大意:一流的AJAX支持——通過AJAX標志增加互動性和靈活性,而且使用這些AJAX標志與普通的Struts標志同樣簡單)”。

    實現原理

    基于不重新發明輪子的原則,Struts 2并沒有開發新的AJAX框架,而是使用時下Java EE平臺中比較流行的AJAX框架——Dojo和DWR。

    最近在Musachy Barroso等同志的無私奉獻下,開發了Struts 2的JSON插件(Plugin),極大地方便了我們輸出JSON結果(Result)。

    JSON插件(Plugin)

    在Struts 2的showcase中的AJAX部分,JSON的結果輸出是通過Freemaker模板實現。這種方法在簡易性和靈活性上都比不上JSON插件,所以JSON插件值得向大家五星推薦。

    下面讓我們看一個JSON插件的例子。

    首先到以下網址http://code.google.com/p/jsonplugin/downloads/list下載JSON插件的JAR包,并將其加入你的WebContent\WEB-INF\lib下。

    接下是本例子的Action代碼:

    package tutorial;

    import java.util.ArrayList;
    import java.util.List;

    import com.googlecode.jsonplugin.annotations.JSON;
    import com.opensymphony.xwork2.ActionSupport;

    public class JsonPluginAction extends ActionSupport {
       
    private static final long serialVersionUID = -6784977600668791997L;
       
       
    private int bookId;
       
    private String title;
       
    private double price;
       
    private List<String> comments;    
       
    private transient String secret1;
       
    private String secret2;

       @JSON(name
    ="ISBN")
       
    public int getBookId() {
           
    return bookId;
       }


       
    public void setBookId(int bookId) {
           
    this.bookId = bookId;
       }


       
    public List<String> getComments() {
           
    return comments;
       }


       
    public void setComments(List<String> comments) {
           
    this.comments = comments;
       }


       
    public double getPrice() {
           
    return price;
       }


       
    public void setPrice(double price) {
           
    this.price = price;
       }


       
    public String getTitle() {
           
    return title;
       }

       
       
    public void setTitle(String title) {
           
    this.title = title;
       }


       @Override
       
    public String execute() {
           bookId
    = 15645912;
           title
    = "Max On Java";
           price
    = 0.9999d;
           comments
    = new ArrayList<String>(3);
           comments.add(
    "It's no bad!");
           comments.add(
    "WOW!");
           comments.add(
    "No comment!");
           secret1
    = "You can't see me!";
           secret2
    = "I am invisible!";
           
    return SUCCESS;
       }

    }
    清單1 src/tutorial/JsonPluginAction.java

    以上代碼值得注意的是,通過@JSON的JAVA注釋(Annotation),我們可以改變JSON結果的屬性名稱,另外帶有transient修飾符與沒有Getter方法的字段(field)都不會被串行化為JSON。

    然后,我們來配置一下此Action,代碼如下:

    <?xml version="1.0" encoding="UTF-8"?>

    <!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
        "http://struts.apache.org/dtds/struts-2.0.dtd"
    >

    <struts>    
       
    <package name="Struts2_AJAX_DEMO" extends="json-default">
           
    <action name="JsonPlugin" class="tutorial.JsonPluginAction">
               
    <result type="json" />
           
    </action>            
       
    </package>
    </struts>
    清單2 src/struts.xml

    上面配置文件的“package”元素和以往不同的是,它擴展了“json-default”而不是“struts-default”。“json-default”是在jsonplugin-0.11.jar包里的struts-plugin.xml中定義的。該文件同時定義了“json”的結果類型,有興趣的朋友可以打開此文件看看。

    發布運行應用程序,在瀏覽器中鍵入:http://localhost:8080/Struts2_Ajax/JsonPlugin.action,出現下載文件對話框,原因是JSON插件將HTTP響應(Response)的MIME類型設為“application/json”。把文件下載下來,用記事本打開,內容如下:

    {"ISBN":15645912,"comments":["It's no bad!","WOW!","No comment!"],"price":0.9999,"title":"Max On Java"}
    清單3 例子1輸出的JSON串

    當然這還不是一個完整的AJAX的例子,下面讓我們寫一個HTML文件將其完成,HTML代碼如下:

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" >
    <head>
       
    <title>JSON Plugin</title>
       
    <script type="text/javascript">    
       
    var bXmlHttpSupport = (typeof XMLHttpRequest != "undefined" || window.ActiveXObject);
         
       
    if (typeof XMLHttpRequest == "undefined" && window.ActiveXObject) {
           
    function XMLHttpRequest() {
               
    var arrSignatures = ["MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0",
                                     
    "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP",
                                     
    "Microsoft.XMLHTTP"];
                                 
               
    for (var i=0; i < arrSignatures.length; i++) {
                   
    try {        
                       
    var oRequest = new ActiveXObject(arrSignatures[i]);            
                       
    return oRequest;        
                    }
    catch (oError) { /*ignore*/ }
                }          
        
               
    throw new Error("MSXML is not installed on your system.");               
            }
        }    
                
       
    function retrieveBook() {        
           
    if(bXmlHttpSupport) {
               
    var sUrl = 'JsonPlugin.action';
               
    var oRequest = new XMLHttpRequest();
                oRequest.onreadystatechange
    = function() {
                   
    if(oRequest.readyState == 4) {                    
                       
    var oBook = eval('(' + oRequest.responseText + ')');
                       
    var bookHolder = document.getElementById('bookHolder');
                       
    var sBook = '<p><b>ISBN: </b>' + oBook.ISBN + '</p>';
                        sBook
    += ('<p><b>Title: </b>' + oBook.title + '</p>');
                        sBook
    += ('<p><b>Price: </b>$' + oBook.price + '</p>');
                        sBook
    += ('<b><i>Comments: </i></b><hr/>');
                       
    for(i = 0; i < oBook.comments.length; i++) {
                            sBook
    += ('<p><b>#' + (i + 1) + ' </b>' + oBook.comments[i] + '</p>');
                        }
                        bookHolder.innerHTML
    = sBook;
                    }
                };
                oRequest.open('POST', sUrl);
                oRequest.send(
    null);
            }
        }
       
    </script>
    </head>
    <body>
       
    <input type="button" value="Retrieve Book" onclick="retrieveBook()" />
       
    <div id="bookHolder"></div>
    </body>
    </html>
    清單4 WebContent/JsonPlugin.html

    以上代碼中,我沒有使用任何的AJAX的Javascript包,而是參考《Professional Javascript For Web Developer》手工創建XHR(XMLHttpRequest),并在XHR完成后使用eval()方法將JSON字符串變為JSON對象。需要注意的是,要調用eval函數時,必須使用“(”和“)”將JSON字符串括起來,否則會出錯的。

    打開http://localhost:8080/Struts2_Ajax/JsonPlugin.html,點擊“Retrieve Book”按鈕,頁面如下圖所示:

    圖1 JsonPlugin.html頁面輸出
    圖1 JsonPlugin.html頁面輸出

    Struts 2與Dojo

    Dojo是開源Javascript工具包,它引了Widget的概念,方便了Javascript面向對象編程(OOP),改進Javascript的事件模型。在此我不打算對此進行深入的講解,有興趣的朋友的可以找網上找一些關于Dojo的資料學習。

    Struts 2基于Dojo編寫一些AJAX標志(在Dojo中稱為Widget),要使用這些標志的AJAX功能,需要將標志的“theme”屬性設為“ajax”。同時,亦需要將加入在<head>與</head>之間加入<s:head theme="ajax" />。當使用這些標志的AJAX功能,有些屬性可能會經常用到,所以我會對這些屬性稍作解釋。

    名稱 描述
    href XHR(XMLHttpRequest)請求的地址
    listenTopics 監聽的Dojo話題(Topic)以觸發自身,如可以在可以通過發布(Publish)相應的話題,通知<s:autocompleter />重新加載其備選項(Options)
    notifyTopics 完成遠程調用后,發出通知,觸發相應的Javascript函數或Dojo Widget
    formId 需要提交到服務器的表單的ID
    formFilter 過濾表單字段的Javascript函數名稱
    indicator 在XHR處理過程中,包含用戶提示的信息的HTML元素的ID,如圖片或DIV等
    表1 常用的AJAX標志屬性

    這些標志包括:<s:a />、<s: submit />、<s:autocompleter />和<s:tree />等,下面我將分別講解。

    1、<s:a />和<s:submit />

    這兩個標志方便了我們的調用XHR實現AJAX,所以上面的HTML如果使用了這兩標志將會變得更簡單,因為我們不用再去理會繁鎖的XHR創建和設定的工作。下面是示例代碼:

    <%@ page language="java" contentType="text/html; charset=utf-8"
        pageEncoding
    ="utf-8"%>
    <%@ taglib prefix="s" uri="/struts-tags"%>

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
       
    <head>
           
    <title>JSON Plugin</title>
           
    <s:head theme="ajax" />
           
    <script type="text/javascript">                    
            dojo.addOnLoad(
    function() {
                dojo.event.topic.subscribe('retrieveBook',
    this, function(data, type, e){
                   
    if(type == 'load') {
                        showBook(data);
                    }
    else if(type == 'error') {
                        alert('Can not retrieve the book');
                    }
                });
            });
            
           
    function showBook(strBook) {
               
    var oBook = eval('(' + strBook + ')');
               
    var bookHolder = document.getElementById('bookHolder');
               
    var sBook = '<p><b>ISBN: </b>' + oBook.ISBN + '</p>';
                sBook
    += ('<p><b>Title: </b>' + oBook.title + '</p>');
                sBook
    += ('<p><b>Price: </b>$' + oBook.price + '</p>');
                sBook
    += ('<b><i>Comments: </i></b><hr/>');
               
    for(i = 0; i < oBook.comments.length; i++) {
                    sBook
    += ('<p><b>#' + (i + 1) + ' </b>' + oBook.comments[i] + '</p>');
                }
                bookHolder.innerHTML
    = sBook;
            }
           
    </script>
       
    </head>
       
    <body>
           
    <s:url id="bookUrl" value="/JsonPlugin.action" />
           
    <s:submit href="%{bookUrl}" theme="ajax" indicator="indicator"
                value
    ="Retrieve Book" align="left" notifyTopics="retrieveBook" />
           
    <s:a theme="ajax" href="%{bookUrl}" indicator="indicator"
                notifyTopics
    ="retrieveBook">Retrieve Book</s:a>
           
    <img id="indicator"
                src
    ="${pageContext.request.contextPath}/images/indicator.gif"
                alt
    ="Loading" style="display:none" />
           
    <div id="bookHolder"></div>
       
    </body>
    </html>
    清單5 WebContent/LinkButton.jsp

    可能上述代碼還不夠簡潔,因為我將HTML格式化的工作都放在Javascript中完成。但如果你的XHR返回的是HTML片段,你可以簡單地將<s:a />或<s:submit />的“targets”屬性設為“bookHolder”即可,詳情大家可以參考Struts 2 Showcase。至于返回HTML片段,可以通過Action + Freemaker完成。

    2、<s:autocompleter />

    Autocomplete是比較經典的AJAX應用,雖然谷歌已經停止使用這一功能,但就Autocompleter自身而言的確是很酷的。下面是一個<s:autocompleter />的例子。

    首先,我要偽造一些字符串數據,代碼如下:

    package tutorial;

    import java.util.ArrayList;
    import java.util.List;

    public final class Datas {
       
    public static final List<String> NAMES;
       
    static {
           NAMES
    = new ArrayList<String>();
           NAMES.add(
    "Alabama");
           NAMES.add(
    "Alaska");
           NAMES.add(
    "American Samoa");
           NAMES.add(
    "Arizona");
           NAMES.add(
    "Arkansas");
           NAMES.add(
    "Armed Forces Europe");
           NAMES.add(
    "Armed Forces Pacific");
           NAMES.add(
    "Armed Forces the Americas");
           NAMES.add(
    "California");
           NAMES.add(
    "Colorado");
           NAMES.add(
    "Connecticut");
           NAMES.add(
    "Delaware");
           NAMES.add(
    "District of Columbia");
           NAMES.add(
    "Federated States of Micronesia");
           NAMES.add(
    "Florida");
           NAMES.add(
    "Georgia");
           NAMES.add(
    "Guam");
           NAMES.add(
    "Hawaii");
           NAMES.add(
    "Idaho");
           NAMES.add(
    "Illinois");
           NAMES.add(
    "Indiana");
           NAMES.add(
    "Iowa");
           NAMES.add(
    "Kansas");
           NAMES.add(
    "Kentucky");
           NAMES.add(
    "Louisiana");
           NAMES.add(
    "Maine");
           NAMES.add(
    "Marshall Islands");
           NAMES.add(
    "Maryland");
           NAMES.add(
    "Massachusetts");
           NAMES.add(
    "Michigan");
           NAMES.add(
    "Minnesota");
           NAMES.add(
    "Mississippi");
           NAMES.add(
    "Missouri");
           NAMES.add(
    "Montana");
           NAMES.add(
    "Nebraska");
           NAMES.add(
    "Nevada");
           NAMES.add(
    "New Hampshire");
           NAMES.add(
    "New Jersey");
           NAMES.add(
    "New Mexico");
           NAMES.add(
    "New York");
           NAMES.add(
    "North Carolina");
           NAMES.add(
    "North Dakota");
           NAMES.add(
    "Northern Mariana Islands");
           NAMES.add(
    "Ohio");
           NAMES.add(
    "Oklahoma");
           NAMES.add(
    "Oregon");
           NAMES.add(
    "Pennsylvania");
           NAMES.add(
    "Puerto Rico");
           NAMES.add(
    "Rhode Island");
           NAMES.add(
    "South Carolina");
           NAMES.add(
    "South Dakota");
           NAMES.add(
    "Tennessee");
           NAMES.add(
    "Texas");
           NAMES.add(
    "Utah");
           NAMES.add(
    "Vermont");
           NAMES.add(
    "Virgin Islands, U.S.");
           NAMES.add(
    "Virginia");
           NAMES.add(
    "Washington");
           NAMES.add(
    "West Virginia");
           NAMES.add(
    "Wisconsin");
           NAMES.add(
    "Wyoming");
       }

    }
    清單6 src/tutorial/Datas.java

    然后是用于獲取和過濾數據的Action,代碼如下:

    package tutorial;

    import java.util.ArrayList;
    import java.util.List;

    import com.opensymphony.xwork2.ActionSupport;

    public class AutocompleterAction extends ActionSupport {
       
    private static final long serialVersionUID = -8201401726773589361L;
       
       
    private List<String[]> names;    
       
    private String start;
       
       
    public void setStart(String start) {
           
    this.start = start;
       }

       
       
    public List<String[]> getNames() {
           
    return names;
       }


       @Override
       
    public String execute() {
           names
    = new ArrayList<String[]>();
           
    if(start == null || "".equals(start.trim())) {
               start
    = "a";
           }

           
    for(String s : Datas.NAMES) {
               
    if(s.toLowerCase().startsWith(start.toLowerCase())) {
                   names.add(
    new String[]{ s, s });
               }

           }

           
    return SUCCESS;
       }

    }
    清單7 src/tutorial/AutocmpleterAction.java

    上述Action會以JSON的形式返回以start開頭的Datas.NAMES的中字符串,以下是此Action的配置:

    <action name="Autocompleter" class="tutorial.AutocompleterAction">
       
    <result type="json">
           
    <param name="root">names</param>
       
    </result>
    </action>
    清單8 Autocompleter Action的配置代碼片段

    在JSON類型結果的參數中加入“root”參數可以設定輸出JSON結果的根,以上述情況為例,如果沒有“root”參數,輸出將為“{ "names": [ ["xxx", "xxx"]...] }”,加了之后變就會成“[ ["xxx", "xxx"]...] ”。接下來,讓我們看看頁面的代碼:

    <%@ page language="java" contentType="text/html; charset=utf-8"
        pageEncoding
    ="utf-8"%>
    <%@ taglib prefix="s" uri="/struts-tags"%>

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
       
    <head>
           
    <title>Struts 2 AJAX - Autocompleter</title>
           
    <s:head theme="ajax" />
       
    </head>
       
    <body>
           
    <h2>
                Autocompleter
           
    </h2>
           
    <s:form action="autocompleterForm">
               
    <s:textfield label="abc" name="abc" />
               
    <tr>
                   
    <td class="tdLabel">
                       
    <label class="label">
                            No AJAX Autocompleter:
                       
    </label>
                   
    </td>
                   
    <td>
                       
    <s:autocompleter theme="simple" name="user"
                            list
    ="@tutorial.Datas@NAMES" />
                   
    </td>
               
    </tr>
               
    <tr>
                   
    <td class="tdLabel">
                       
    <label class="label">
                            AJAX Autocompleter:
                       
    </label>
                   
    </td>
                   
    <td>
                       
    <s:url id="dataUrl" value="/Autocompleter.action" />
                       
    <s:autocompleter theme="ajax" name="start" href="%{dataUrl}"
                            loadOnTextChange
    ="true" loadMinimumCount="1" indicator="indicator"
                            autoComplete
    ="false" showDownArrow="false" />
                       
    <img id="indicator"
                            src
    ="${pageContext.request.contextPath}/images/indicator.gif"
                            alt
    ="Loading" style="display:none" />
                   
    </td>
               
    </tr>
           
    </s:form>
       
    </body>
    </html>
    清單9 WebContent/Autocompleter.jsp

    上述頁面包含兩個<s:autocompleter />標志,前者使用“simple”模板,所以不具有AJAX功能,它的數據將以HTML方式輸出到最終頁面里;而后者則使用了“ajax”模板,每當輸入框的值發生改變時,它都向URL“/Autocompleter.action”發送請求,Action根據請求中的start參數的值,返回相當的JSON,在請求完成后頁面通過回調函數改變輸入框的下拉提示,效果如下圖所示:

    圖2 Autocompleter.jsp頁面輸出 
    圖2 Autocompleter.jsp頁面輸出

    3、<s:tree />

    樹是是比較常用的數據結構,因為它可以很好地體現真實世界中對象之間的關系。<s:tree />的使用也相對簡單,但需要說明的是——Struts 2.0.6 GA版本的<s:tree />是有BUG的,大家可以點擊這個鏈接https://issues.apache.org/struts/browse/WW-1813了解詳細的情況。這個BUG主要是在<s:tree />的通過“treeCollapsedTopic”、“treeExpandedTopic”和“treeSelectedTopic”設定的話題(Topic)都沒有起作用,上述鏈接相應給出了解決方法,但我認為該方法太麻煩(需要自己重新編譯和打包Struts 2),所以下面的例子,我將另辟徯徑,請參考以下代碼。

    <%@ page language="java" contentType="text/html; charset=utf-8"
        pageEncoding
    ="utf-8"%>
    <%@ taglib prefix="s" uri="/struts-tags"%>

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
       
    <head>
           
    <title>Struts 2 AJAX - Tree</title>
           
    <s:head theme="ajax" debug="true" />
           
    <script type="text/javascript">
               
    function treeNodeSelected(arg) {
                    alert(arg.source.title
    + ' selected');
                }
                dojo.addOnLoad(
    function() {                
                   
    var s = dojo.widget.byId('parentId').selector;                
                    dojo.event.connect(s, 'select', 'treeNodeSelected');
                });
           
    </script>
       
    </head>
       
    <body>
           
    <h2>
                Tree
           
    </h2>
           
    <div style="float:left; margin-right: 50px;">
               
    <s:tree label="parent" id="parentId" theme="ajax"
                    templateCssPath
    ="/struts/tree.css" showRootGrid="true"
                    showGrid
    ="true">
                   
    <s:treenode theme="ajax" label="child1" id="child1Id">
                       
    <s:treenode theme="ajax" label="grandchild1" id="grandchild1Id" />
                       
    <s:treenode theme="ajax" label="grandchild2" id="grandchild2Id" />
                       
    <s:treenode theme="ajax" label="grandchild3" id="grandchild3Id" />
                   
    </s:treenode>
                   
    <s:treenode theme="ajax" label="child2" id="child2Id" />
                   
    <s:treenode theme="ajax" label="child3" id="child3Id" />
                   
    <s:treenode theme="ajax" label="child4" id="child4Id" />
                   
    <s:treenode theme="ajax" label="child5" id="child5Id">
                       
    <s:treenode theme="ajax" label="gChild1" id="gChild1Id" />
                       
    <s:treenode theme="ajax" label="gChild2" id="gChild2Id" />
                   
    </s:treenode>
               
    </s:tree>
           
    </div>
       
    </body>
    </html>
    清單10 WebContent/Tree.jsp

    因為Dojo的樹控件,即使在沒有設定“selector”情況下,也會自動生成一個默認的Selector,所以只要將其事件綁定到特定的事件處理函數即可。

    打開http://localhost:8080/Struts2_Ajax/Tree.jsp,點擊任一樹節點,頁面如下圖所示:

    圖3 Tree.jsp頁面輸出 
    圖3 Tree.jsp頁面輸出

    總結

    我原本打算用一篇文章寫完這個“Struts 2與AJAX”。不過在寫的過程中,發現內容越來越多。如果勉強寫成一篇,朋友們讀起來也會很麻煩,所以我決定分開幾部分,本文為第一部分。

    另外,之前有的朋友建議我建一個Google的討論組,方便大家討論問題。我覺得這個提議非常好,一直以來都是“一人寫,大家留言”,這種相對單向的方式不免有所欠缺,而且本人所知也有限,開個討論組大家可以相互討論,共同進步。

    因為Struts2已經被創建,所以申請了“struts2cn”,有興趣的朋友,歡迎加入。

    posted on 2007-06-12 18:31 Max 閱讀(81164) 評論(96)  編輯  收藏 所屬分類: Struts 2.0系列

    評論:
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-06-12 19:53 | yy
    我一直在關注你的blog,在這里學到了不少關于struts2的東西,可否寫一下關于struts2和ext集成的例子,謝謝!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-12 20:34 | 海邊沫沫
    好文章,頂  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-06-13 09:19 | javaman
    終于等到你發帖了!~  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-13 09:28 | 千山鳥飛絕
    建議將struts2樹型寫得更詳細一點,因為現在個人覺得struts2的樹型似乎還是一次性的讀取所有數據。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-13 13:27 | 有貓相伴的日子
    沒有說到DWR與struts2結合的例子  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-13 18:28 | divid
    老兄,現在市面上好像沒有struts2 book 你可以整理一下出一本.滿足一下市場的需求.這可是機會呀!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-06-14 09:06 | G_G
    頂上
    好東西  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-14 09:31 | Max
    @千山鳥飛絕
    可以的話,我會把它完善的。
    @有貓相伴的日子
    在第二部分應該會DWR與Struts 2的例子。
    @divid
    值得考慮,不過還沒有出版商找我:-)  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-14 09:34 | Max
    Struts 2.0.8 GA發布了,不過,我昨晚試了一下,似乎<s:tree />標志的BUG還沒有解決。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-14 14:56 | look
    請教個問題:
    我頁面中使用的是框架,就是左面菜單,右面頁面,現在我是不知道怎么把action的值傳到頁面了,不知道怎么實現。請幫想個辦法,謝謝!
      回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-14 23:05 | Max
    @look
    和普通的做法一樣。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-15 09:47 | look
    <s:param name="objectid" value="<%=systemSetPO.getSyscode()%>"/>
    我的systemSetPO.getSyscode()的值是001,但從<s:param>中的出的結果
    是1,有什么辦法能得到是001?謝謝  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-06-16 09:58 | Oliver
    @Max
    dojo框架的tabContainer控件不支持中文作標簽的標題,有沒什么辦法可以解決啊,謝謝  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-17 01:33 | 甜菜侯爵
    一路看來
    Max的系列指南文章對我學習struts幫助實在是太大了!
    真是萬分感謝!

    不知現在Google論壇是否已經建好?
    我想如能進一步和一同學習struts2的朋友進行詳細討論,收獲會更大。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-19 00:56 | Max
    @甜菜侯爵
    論壇已經建好http://groups.google.com/group/struts2cn,歡迎加入討論。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-19 00:59 | Max
    @look
    這需要根據你的systemSetPO.getSyscode()返回是什么類型?可能要自己格式一下,另外,<s:param />的value屬性是支持OGNL,所以應該盡量避免使用<%%>的寫法。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-19 01:01 | Max
    @Oliver
    我會寫一篇關于AJAX出現的中文問題的解決方法的文章(如果這段有空的話)。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-06-19 07:40 | Oliver
    @Max
    好的,期待后續大作  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-19 09:43 | furong
    建議把樹的部分寫的再詳細點
    文中涉及到的是靜態樹
    能不能把動態樹的情況也講一下
    不勝感激!!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-19 12:35 | look
    @Max
    請問在struts2.0中session是怎么用的,我現在做一個項目的登陸模塊,我想把登陸信息保存住,但struts2.0中我用了SessionAware,ServletRequestAware,ServletResponseAware,但是登陸信息還不保存不住,不知道為什么?不知道您是怎么做的?把解決一下,謝謝!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-19 22:08 | Max
    @furong
    好的,我會在以后的文章多提及的。
    @look
    這通常的做法無有區別,請參考《http://www.tkk7.com/max/archive/2006/10/25/77157.aspx》,如果你的通過SessionAware獲得的Map類型的session中屬性集合(假如名為att),則應用使用att.put("user", "Max");
    如果是通過HttpSession session = request.getSession()得到的session,則應使用session.setAttribute("user", "Max")。
    希望這對你有用。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-22 14:38 | divid
    用標簽<s:tree>不能顯示,提示:找不到dojo?
    /struts/這個目錄在那啊
    請老兄幫忙!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-22 16:00 | 楊愛友
    怎么才能加你為好友  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-22 22:17 | Max
    @楊愛友
    你可以通過Google Talk:max.m.yuan@gmail.com找到我。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-25 15:14 | jpma
    為何我的工程中加入“jsonplugin-0[1].13.jar”后就tomcat就不能啟動?
    console中出現信息為
    java.lang.UnsupportedClassVersionError: Bad version number in .class file
    ......
    我的jdk為1.5版本,難道jsonplugin是用jdk1.6版本編譯出來的?  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-25 22:45 | Max
    @jpma
    不是,我使用的JDK就是5.0版本,你是否安裝了多個JDK,請確認你的TOMCAT所使用的JDK的版本。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-25 22:53 | Max
    @divid
    你可以在struts-core-2.0.6.jar或struts-core-2.0.8.jar包中的org.apache.struts2.static.dojo的路徑下找到。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-06-27 10:16 | jpma
    @Max
    已經確定是JDK版本的問題,可能我下載的jsonplugin版本是新的吧,我安裝了jre1.6后,將tomcat的“Java Virtural Machine”改為1.6的jvm.dll后問題就解決了。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-01 17:38 | JJ
    autocompleter的例子
    無法執行???
    為什麼  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-01 20:26 | JJ
    請問如何在<s:autocompleter ....
    的Tag裡加入JavaScript onchange()的function
    ???  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-07-02 18:36 | Sivyer
    求助個問題

    我用 struts2 的 ajax提交表單時,在服務端得到的值是 null
    去掉 頭部的 <s:head theme="ajax"> 提交正常
    這是什么問題?
    弄了幾天了,請幫忙解決一下,先謝謝了!

    下邊是部分代碼

    <s:form action="updatePersonInfo.action" method="post" id="frm1"
    namespace="/web/usersinfo">

    <s:hidden name="userbase.id" />
    <s:hidden name="userbase.userId" />
    <s:textfield name="test"></s:textfield>
    <s:textfield label="%{getText('usersbase.label.name')}"
    name="userbase.name" required="true" />


    提交按鈕:
    <s:submit theme="ajax" targets="updateResultDiv" value="ddd" formId="frm1"></s:submit>
      回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-02 23:08 | Max
    @JJ
    你可以使用notifyTopics屬性,如
    <s:autocompleter theme="simple" name="user" list="@tutorial.Datas@NAMES" notifyTopics="/acChange"/>;
    在<head></head>之間加入:
    <script type="text/javascript">
    dojo.addOnLoad(function() {
    dojo.event.topic.subscribe('/acChange', this, function(data, type, e){
    alert(data + ', ' + type + ', ' + e);
    });
    });
    </script>
    希望這對你有用。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-02 23:12 | Max
    @Sivyer
    你可以試一下在<s:submit />中加入href屬性,如:
    <s:submit theme="ajax" targets="updateResultDiv" value="ddd" formId="frm1" href="/web/usersinfo/updatePersonInfo.action" />。
    希望這可以解決你的問題。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-07-13 19:19 | Stone
    文章太好了 !感謝作者。
    請問我現在有個問題,就是使用<s:autocompleter ....
    的時候,我如果設置了list屬性值,比如: <s:autocompleter list="userMap" ..... 我如果不設置notifyTopics這個屬性或者我設置了notifyTopics這個屬性,但是沒有引入dojo.event.topic.subscribe這個js代碼,當我用鼠標點右邊的小藍tab來選擇列表屬性時,點幾下就會出現java script Error. Line :4872, object Error.
    這問題我一直不知道是什么原因造成的,我看struts showcase上也有這個問題.只是showcase上如果result返回的是js文件時,才沒有這個問題,但是使用list屬性來initial這個tag值就出問題了。
    我現在只能通過對每個autocompleter 設置notifyTopics這個屬性,并且再定義一個空的dojo.event.topic.subscribe來解決這個問題。
    請問還有別的解決方案么?  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-07-13 19:20 | Stone
    另外,我使用的是struts2.0.8版本  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-20 10:51 | hae
    個人感覺<s:autocompleter>和<s:tree>的輸出樣式不是很好看,
    不知道是否可以自定義CSS?  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-25 19:00 | 明人
    “在Struts 2的showcase中的AJAX部分,JSON的結果輸出是通過Freemaker模板實現。”

    注意,不是“Freemaker”而是“Freemarker”(我喜歡將其直譯為“自由標記者”),雖然僅僅只是少了一個字母'r',但卻容易造成誤解,我們程序員講究的就是嚴謹的治學態度。

    希望max兄在寫出精品的同時,更能抓住細節,雖然很辛苦,但您的一舉一動都會影響大批立志于java技術的后輩,可以說,在某種意義上,您已經是一面旗幟了。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-25 23:23 | Max
    @明人
    過獎了,我在發文章之前會進行一下粗略的校對,但這樣的錯誤還是在所難免。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-25 23:29 | Max
    @Stone
    Sorry, 不太明白你的意思。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-28 15:46 | d
    例子說的 不明不白 配置文件也 很多沒帖完全 誤人時間  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-31 10:49 | Adma
    基于不重新發明輪子的原則,Struts 2并沒有開發新的AJAX框架,而是使用時下Java EE平臺中比較流行的AJAX框架——Dojo和DWR。

    DWR 官方說的? 我怎么看文檔里只說是Dojo??

    The framework provides a set of tags to help you ajaxify your applications, on Dojo. Dojo 0.4 is bundled with the distribution.  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-07-31 23:34 | Max
    @Adma
    據我所知,Struts 2在Struts 2.0.6使用DWR實現AJAX表單校驗。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-08-01 10:04 | Adma
    @Max
    有文檔嗎?給個鏈接,謝謝。
      回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-08-10 09:01 | dxyy
    請問,我的struts2中的datetimepicker這個控件怎么沒有用,我按照網上的說法把代碼寫好了編繹運行后,我看不到這個組件.  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-08-22 09:57 | Stone
    @Max
    謝謝 Max 你的關注,我現在再去看了下我提的問題,的確沒有描述清楚。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-08-23 14:27 | 甲生
    我想把spring也整合進去,但是出現了問題,如下配置<package name="Struts2_AJAX_DEMO" extends="json-default"> 當extends不是
    struts-default時,依賴注入不能實現,請問老大有可什么解決的的方法  回復  更多評論
      
    # jsonplugin[未登錄] 2007-09-12 17:34 | Daniel
    Struts 2 JSON Plugin
    JSON Plugin
    這兩個插件有什么區別呀?有沒有JSON Plugin 的參考文檔或api呀在哪里呢?
    謝謝max大哥哥這么多好的文章  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-09-13 15:48 | why
    java.lang.NoClassDefFoundError: Lorg/codehaus/plexus/PlexusContainer;
    at java.lang.Class.getDeclaredFields0(Native Method)
    at java.lang.Class.privateGetDeclaredFields(Class.java:2232)
    at java.lang.Class.getDeclaredFields(Class.java:1715)
    at com.opensymphony.xwork2.inject.ContainerImpl.addInjectors(ContainerImpl.java:102)
    at com.opensymphony.xwork2.inject.ContainerImpl$1.create(ContainerImpl.java:84)
    at com.opensymphony.xwork2.inject.ContainerImpl$1.create(ContainerImpl.java:82)
    at com.opensymphony.xwork2.inject.util.ReferenceCache$CallableCreate.call(ReferenceCache.java:155)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:269)
    at java.util.concurrent.FutureTask.run(FutureTask.java:123)
    at com.opensymphony.xwork2.inject.util.ReferenceCache.internalCreate(ReferenceCache.java:81)
    at com.opensymphony.xwork2.inject.util.ReferenceCache.get(ReferenceCache.java:121)
    at com.opensymphony.xwork2.inject.ContainerImpl$ConstructorInjector.<init>(ContainerImpl.java:329)
    at com.opensymphony.xwork2.inject.ContainerImpl$5.create(ContainerImpl.java:299)
    at com.opensymphony.xwork2.inject.ContainerImpl$5.create(ContainerImpl.java:298)
    at com.opensymphony.xwork2.inject.util.ReferenceCache$CallableCreate.call(ReferenceCache.java:155)
    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:269)
    at java.util.concurrent.FutureTask.run(FutureTask.java:123)
    at com.opensymphony.xwork2.inject.util.ReferenceCache.internalCreate(ReferenceCache.java:81)
    at com.opensymphony.xwork2.inject.util.ReferenceCache.get(ReferenceCache.java:121)
    at com.opensymphony.xwork2.inject.ContainerImpl.getConstructor(ContainerImpl.java:562)
    at com.opensymphony.xwork2.inject.ContainerImpl.inject(ContainerImpl.java:460)
    at com.opensymphony.xwork2.inject.ContainerImpl$7.call(ContainerImpl.java:501)
    at com.opensymphony.xwork2.inject.ContainerImpl.callInContext(ContainerImpl.java:549)
    at com.opensymphony.xwork2.inject.ContainerImpl.inject(ContainerImpl.java:499)
    at com.opensymphony.xwork2.config.impl.LocatableFactory.create(LocatableFactory.java:32)
    at com.opensymphony.xwork2.inject.ContainerBuilder$4.create(ContainerBuilder.java:134)
    at com.opensymphony.xwork2.inject.Scope$2$1.create(Scope.java:49)
    at com.opensymphony.xwork2.inject.ContainerImpl$ParameterInjector.inject(ContainerImpl.java:431)
    at com.opensymphony.xwork2.inject.ContainerImpl.getParameters(ContainerImpl.java:446)
    at com.opensymphony.xwork2.inject.ContainerImpl.access$000(ContainerImpl.java:48)
    at com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector.inject(ContainerImpl.java:288)
    at com.opensymphony.xwork2.inject.ContainerImpl$2.call(ContainerImpl.java:117)
    at com.opensymphony.xwork2.inject.ContainerImpl$2.call(ContainerImpl.java:115)
    at com.opensymphony.xwork2.inject.ContainerImpl.callInContext(ContainerImpl.java:542)
    at com.opensymphony.xwork2.inject.ContainerImpl.injectStatics(ContainerImpl.java:114)
    at com.opensymphony.xwork2.inject.ContainerBuilder.create(ContainerBuilder.java:494)
    at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reload(DefaultConfiguration.java:145)
    at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:52)
    at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:395)
    at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:452)
    at org.apache.struts2.dispatcher.FilterDispatcher.init(FilterDispatcher.java:201)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:223)
    at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:304)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:77)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:3600)
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4193)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1013)
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:718)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1013)
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:442)
    at org.apache.catalina.core.StandardService.start(StandardService.java:450)
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:709)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:551)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:585)
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:294)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:432)
    - Error filterStart

    struts2.0.1 換成sturts2.0.8出現以上問題,為什么啊..知道的說下.謝謝  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-09-17 17:15 | 獨孤蟹
    s:autocompleter names 里如果有中文 怎么處理啊? 我debug在action中看到中文都是亂碼  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-09-18 14:05 | Stone
    你好 ,Max, 有個autocomplete的問題一直困擾了我好久 ,我斷斷續續找資料大概2個月了依舊沒有能找到答案。我的問題描述比較長,而且有附件什么的,這里寫的不方便。我寫在這個地址上:
    http://www.javaeye.com/topic/100190
    我在apache網站上找了bug日志,好像也沒有提到這個issue,所以我想可能是我的用法不對,如果你能幫我解說一下,萬分感謝。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-09-30 16:59 | a
    @yy

    關于struts2和ext的集成可以用struts2jsonplugin,很方便做grid
      回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-10-07 13:24 | edward
    自動完成,對中文沒作用  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-10-09 17:33 | jackson
    我完全按照樓主的例子做了Autocomplete,可是運行后點擊三個框都沒反應,也不報錯,是瀏覽器設置的原因還是什么原因啊?  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2007-10-10 13:06 | jackson
    問題解決了,犯了個不該犯的錯誤,原來把類Datas忘放到tomcat下了!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-10-12 10:28 | referee
    我按著你說的方法做的
    jsonplugin的包放到了lib下面,struts.xml也是照寫的,可是tomcat報錯。

    There is no result type defined for type 'json' mapped with name 'success' - result - file:/F:/cvs_root/struts/WebContent/WEB-INF/classes/struts.xml:42:34

    已經設置extends="json-default",還是沒有json的的resultType,請高人指點  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2007-12-19 14:25 | 網事
    我按照你說的做..我遇到了個問題.給個聯系方式?QQ或者是MSN  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-01-02 11:39 | javer
    正準備在STRUTS2中用AJAX  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-01-05 15:25 | agoo
    期待struts2和ext的集成例子出現,
    感謝Max,使我在struts2中少走了很多路!
      回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2008-01-07 14:55 | liu
    Auto不能成功,誰能給個成功的例子啊  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-01-08 17:48 | xx
    sod,sodos.jdosslss  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2008-01-18 10:38 | apple
    樓主,我發生了這個異常,不知是什么原因,請幫忙解決下
    Servlet.service() for servlet default threw exception
    java.lang.IllegalAccessException: Class com.googlecode.jsonplugin.JSONWriter can not access a member of class org.apache.commons.dbcp.PoolingDataSource$PoolGuardConnectionWrapper with modifiers "public"  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-01-18 13:13 | grttr
    rewqrewqrwq  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-01-18 13:14 | grttr
    yyyyyyyyyyyy  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2008-01-30 13:15 | javaman
    這篇blog很早就看過了,當時看還沒什么感覺
    最近在研究ext的grid,用到了json ,再回來看struts2中的json,收獲很大
    感謝max~~~~  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-01-31 13:59 | kongguoan
    我照做了您所有的例子。當我看到自動完成的這個例子的時候我異常的興奮。但是上面都是只支持英文。。我想了很多辦法都沒有讓它支持中文。。這個問題困擾了我1個多星期了。。希望您能幫助一下。。謝謝怎么才能讓自動完成支持中文呢????  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-03-07 10:57 | sniperking
    中文好像支持不是很好,試了很久,需要改Tomcat配置,
    TOMCAT server.xml中 <Connector
    port="8080"中加URIEncoding="UTF-8"
    URIEncoding需要和頁面中的<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    一致,不過好像頁面上匹配有問題,找不到原因
      回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-03 09:56 | 要鮮花
    不錯的東西!!!!
      回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-03 09:57 | 要鮮花
    你好!!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-03 10:02 | 要鮮花1111
    12334344343  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-03 10:11 | 要鮮花1111
    22222  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-06 18:27 | shoru
    中文是支持的!不過是在火狐里支持,在IE里就不支持了,我在start被用作數據庫查詢的關鍵字之前,對其進行了重新編碼,OK了就。
    String sutf8 = new String(start.getBytes("iso8859-1"),"utf8");

    誰告訴我為什么在IE里不行在火狐行啊!難道是IE和火狐的默認編碼不一樣???  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2008-04-07 17:30 | 哈哈
    困擾了我一天,不支持中文,輸入中文直接就不能觸發,想了好多辦法都不行,郁悶  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-25 11:16 | 小輝
    不錯!max,demo寫的很詳細,受到不少幫忙,在此表示感謝。繼續努力。
    頂!!!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-28 15:34 | origo
    <script type="text/javascript">
    dojo.addOnLoad(function() {
    dojo.event.topic.subscribe('retrieveBook', this, function(data, type, e){
    if(type == 'load') {
    showBook(data);
    } else if(type == 'error') {
    alert('Can not retrieve the book');
    }
    });
    });

    function showBook(strBook) {
    var oBook = eval('(' + strBook + ')');
    var bookHolder = document.getElementById('bookHolder');
    var sBook = '<p><b>ISBN: </b>' + oBook.ISBN + '</p>';
    sBook += ('<p><b>Title: </b>' + oBook.title + '</p>');
    sBook += ('<p><b>Price: </b>$' + oBook.price + '</p>');
    sBook += ('<b><i>Comments: </i></b><hr/>');
    for(i = 0; i < oBook.comments.length; i++) {
    sBook += ('<p><b>#' + (i + 1) + ' </b>' + oBook.comments[i] + '</p>');
    }
    bookHolder.innerHTML = sBook;
    }

    嘗試采用這種方式,怎么我得到的type 是before的,而且firefox debug輸出
    DEBUG: XMLHttpTransport error callback failed: TypeError: node has no properties

    請大哥明示呀。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-28 15:35 | origo
    用頭先的javascript的方式執行正常  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-04-30 00:19 | Luckyrain
    Perfect Contents!!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-06-27 14:49 | javaflying
    大俠,請教一個問題:我在使用struts2.0標簽
    <s:autocompleter theme="ajax" name="zxw01" href="%{userCode}"
    loadOnTextChange="true" loadMinimumCount="1" indicator="indicator"
    autoComplete="false" showDownArrow="false" onchange="getuserName()" theme="simple"/>
    如何使用onchange事件.我上面的用法怎么不能激發這一事件!!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-06-27 15:28 | javaflying
    發現onchange事件不能激發的原因是因為與struts2.0的ajax框架發生沖突!
    <s:head theme="ajax" debug="true"/>
    請問樓主我兩者都要用,如何解決沖突的問題!!
    謝謝!!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-09-19 13:12 | sebatinsky
    能夠運行,分析當中,完全看了帖子.  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-09-26 18:00 | N.J.Paul
    不好意思,初學者--
    <script type="text/javascript">
    function show_user_details(id) {
    document.frm_user.userid.value = id;
    dojo.event.topic.publish("show_detail");
    }
    </script>
    為什么我直接這樣寫,說publish方法找不到啊?  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-09-28 13:27 | N.J.Paul
    問題已解決,JavaScript提示錯誤不影響程序正確執行。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-11-17 17:23 | yihaijian
    太強了,謝謝你,讀了你的博客收獲真的非常大  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-11-21 08:41 | oasis
    Max在么?任何高手都可以解答。。。
    那個autocompleter實現不了啊?什么原因???急。。。謝謝////  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2008-11-27 21:34 | 初學者
    使用了 json 在 action 里 不能直接 調用某個域模型了嗎

    是不是都要寫成 很多的 字段 然后再??調用一定的業務邏輯操作?

    那些字段有什么好的辦法 簡化嗎  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2009-04-08 18:28 | ccue
    function loadAjaxCommodity(commodityId) {
    dojo.io.bind({
    url:"../ajax/loadCommodity.action?id="+commodityId,
    handle:drawTable,
    method:"GET",
    sync:false,
    mimetype:"text/json"

    });
    }
    為什么在IE中只發送一次請求呢  回復  更多評論
      
    # TMD,這文章太棒了~![未登錄] 2009-04-18 22:14 | 小毅
    終于看到一篇完整的示例,完整的代碼。就是要這樣撒,語言口語化 簡單明了 很不錯!!!!!!!!!!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2009-04-27 16:33 | 飛翔
    你好 著個例子好象有點問題
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" >
    <head>
    <title>JSON Plugin</title>
    <script type="text/javascript">
    var bXmlHttpSupport = (typeof XMLHttpRequest != "undefined" || window.ActiveXObject);

    if (typeof XMLHttpRequest == "undefined" && window.ActiveXObject) {
    function XMLHttpRequest() {
    var arrSignatures = ["MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0",
    "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP",
    "Microsoft.XMLHTTP"];

    for (var i=0; i < arrSignatures.length; i++) {
    try {
    var oRequest = new ActiveXObject(arrSignatures[i]);
    return oRequest;
    } catch (oError) { /*ignore*/ }
    }

    throw new Error("MSXML is not installed on your system.");
    }
    }



    function retrieveBook() {
    if(bXmlHttpSupport) {
    var sUrl = 'JsonPlugin.action';
    var oRequest = new XMLHttpRequest();
    oRequest.onreadystatechange = function() {
    if(oRequest.readyState==4) {
    var oBook = eval('(' + oRequest.responseText + ')');
    var bookHolder = document.getElementById('bookHolder');
    var sBook = '<p><b>ISBN: </b>' + oBook.ISBN + '</p>';
    sBook += ('<p><b>Title: </b>' + oBook.title + '</p>');
    sBook += ('<p><b>Price: </b>$' + oBook.price + '</p>');
    sBook += ('<b><i>Comments: </i></b><hr/>');
    for(i = 0; i < oBook.comments.length; i++) {
    sBook += ('<p><b>#' + (i + 1) + ' </b>' + oBook.comments[i] + '</p>');
    }
    bookHolder.innerHTML = sBook;
    }
    };
    oRequest.open('POST', sUrl);
    oRequest.send(null);
    }
    }
    </script>
    </head>
    <body>
    <input type="button" value="009Retrieve Book" onclick="retrieveBook()" />
    <div id="bookHolder"></div>
    </body>
    </html>

    運行時eval()這里通不過!!希望你調試,最好能將調試好的代碼發給我,謝謝!
    zhangxiong1203@163.com  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2009-06-16 10:38 | JASON
    @甲生
    修改JAR里的配置文件,extends=“STRUTS-DEFAULT”然后保存下,再把修改的文件覆蓋到你的工程里就哦了  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2009-06-21 15:53 | qlknight
    MAx你好,我最近一直在看你的例子學習struts2
    但是在這個例子的時候遇到了頁面編譯不通這的問題,經過一翻測試感覺在用
    <s:a />和<s:submit />的時候要做以個修改。
    a:導入dojo包<%@ taglib prefix="sx" uri="/struts-dojo-tags" %>
    b: <head><s:head/><sx:head/></head>
    c:標簽用<sx:a>,<sx:submint>其中不要加入theme="ajax"屬性。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2009-07-23 15:08 | halley
    <td>
    <s:url id="dataUrl" value="autocompleter.action" />
    <s:autocompleter theme="ajax" name="start" href="%{dataUrl}"
    loadOnTextChange="true" loadMinimumCount="1" indicator="indicator"
    autoComplete="false" showDownArrow="false" />
    <img id="indicator"
    src="${pageContext.request.contextPath}/ecside/images/gird/loading.gif"
    alt="Loading" style="display: none" />
    </td>

    已經可以取到值了,頁面上為什么不能顯示?  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2009-11-19 11:10 | 鐘艷明
    突然喜歡上了struts2.0 ,發現技術的更新真是給我莫大的驚喜!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2010-01-15 13:49 | corrine
    The import com.googlecode cannot be resolved  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2010-08-23 15:08 | cosplay
    突然喜歡上了struts2.0 ,發現技術的更新真是給我莫大的驚喜!  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分) 2010-08-23 15:09 | cosplay
    以上代碼中,我沒有使用任何的AJAX的Javascript包,而是參考《Professional Javascript For Web Developer》手工創建XHR(XMLHttpRequest),并在XHR完成后使用eval()方法將JSON字符串變為JSON對象。需要注意的是,要調用eval函數時,必須使用“(”和“)”將JSON字符串括起來,否則會出錯的。  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2013-04-17 14:35 | tang
    單擊節點后,不能彈出alert框,為什么,樓主  回復  更多評論
      
    # re: Struts 2與AJAX(第一部分)[未登錄] 2015-12-29 09:54 | 1
    11  回復  更多評論
      
    主站蜘蛛池模板: 国产AV无码专区亚洲AV毛网站 | 19禁啪啪无遮挡免费网站| 麻豆成人精品国产免费| 亚洲专区先锋影音| 亚洲视频免费在线观看| 亚洲一区综合在线播放| 91福利免费体验区观看区| 亚洲国产精品成人久久久| 丁香花免费完整高清观看| 亚洲综合色丁香婷婷六月图片| 亚洲国产成人无码AV在线| 成人在线视频免费| 国产成人 亚洲欧洲| 永久免费看bbb| 夜夜爽妓女8888视频免费观看| 久草免费手机视频| 精品亚洲A∨无码一区二区三区| 久久精品国产亚洲AV忘忧草18| 大桥未久亚洲无av码在线| 免费永久看黄在线观看app| 久久精品成人免费观看97| 亚洲av日韩av激情亚洲| 日本一卡精品视频免费| 亚洲人成7777影视在线观看| 国拍在线精品视频免费观看 | 国产情侣久久久久aⅴ免费| 亚洲中文字幕无码久久精品1 | 无码人妻一区二区三区免费| 色噜噜噜噜亚洲第一| 国产亚洲美女精品久久久| 一级毛片在线免费看| 亚洲va成无码人在线观看| 国产免费人人看大香伊| 日本高清不卡aⅴ免费网站| 亚洲欧洲精品在线| 国产高清在线免费| 99久久婷婷免费国产综合精品| 亚洲人成网站18禁止一区| 最近免费字幕中文大全视频| 久久精品亚洲日本波多野结衣| 思思re热免费精品视频66|