• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 64, 文章 - 11, 評論 - 12, 引用 - 0
            數據加載中……

            XmlDom 用法小談

            XmlDOM  用法小談

                    今天,我覺得自己的情緒不夠好,我看他們的設計太不考慮性能方面的問題。而一味地講究不要冗余,是啊教科書上也老是說數據庫的設計要達到什么樣的標準。我個人卻老是覺得對適當地用冗余能換來大的性能提升是很有幫助的。我這個人過于死板了些吧?所以把這種情緒帶進了工作,覺得很是不該。開篇寫了題外話。

                    前兩天我設計了一個頁面,這是一個多級聯動的頁面,當選了項目后,項目后面的單元格中的下拉框中出現與這個項目對應的方法,方法過后則是出現儀器,項目還聯動著標準。當初考慮性能上的問題我在這個頁面中采用了AJAX(AjaxPro)技術,經過使用發現了其中的一個很嚴重的錯誤(程序員愛把它稱為BUG,但我認為沒有滿足要求的就是錯誤)。當點了一單元格時,會異步回到服務端拿數據,而在這期間用戶是可以點其它的地方,這時候返回來的數據只會寫在當前活動的單元格中,但這時活動的單元格卻早已不是源目標了。所以出現了這個難以忍受的錯誤。我們不能要求或者假設用戶不以很快的類似玩游戲的速度來操作MOUSE。所以我的這個設計構想是錯誤的。

                    鑒于上面的原因,我決定對頁面做如下的修改。在載入頁之初,就通過服務端預期地把這個數據組強成XML文件放到頁面上去,而頁面單擊找數據也就在客戶端可以完成。這樣就會大提高反應的速試了,也不會出現前面說的在這個異步的過程中客戶的操作而引發錯誤。

                  在服務端的工作(這是C#做的):我先把數據組織成XML文件,進而把它放在頁面上。在服務端我采用了XmlWritter這個類。用法如下
            StringBuilder sb=new StringBuilder();
                    XmlWriterSettings settings 
            = new XmlWriterSettings();
                    settings.Indent 
            = true;
                    settings.OmitXmlDeclaration 
            = true;
                    settings.NewLineOnAttributes 
            = false;
                    _writer 
            = XmlWriter.Create(sb,settings);
            _writer.WriteStartDocument();

                   在上面我們就構造好了XML寫入器了。而在以下就只要調用下面幾個方法就可以了。
            _writer.WriteStartElement("ITEMS");
            _writer.WriteStartElement(
            "ITEM");
            _writer.WriteAttributeString(
            "ID","10");
            _writer.WriteAttributeString(
            "Name","PH");
            _writer.WriteEndElement();
            _writer.WriteFullEndElement()

            //產生出來的樣子
            <ITEMS>
               
            <ITEM ID="10" Name="PH"/>
            </ITEMS>
                    好了上面的代碼可以讓我產生出一個XML來了。

                   上面準備好服務端,現在我得開始客戶端了。這里我用到了IE瀏覽器中的XMLDOM這個組件了,在別的瀏覽器中也有另處的DOM組件的,其操作和語法甚至函數上都有很大相同的了。
            xmlDom=new ActiveXObject("MSXML2.DOMDocument");
            xmlDom.loadXML(strXml);//這是一個字符串
            var root=xmlDom.selectSingleNode("ITEMS");
            var items=root.selectNodes("ITEM");//找ROOT下所有的ITEM子節點。
            var item=root.selectSingleNode("ITEM[@id=10]");//則是找其下一個ITEM其ID屬性為10了。
            關于XQL的語法,我在有空時會以一個短文來說一說的了。

            posted on 2007-11-09 17:17 Robertxiao 閱讀(472) 評論(0)  編輯 收藏 引用 所屬分類: 天馬行空

            国产亚洲综合久久系列| 伊人久久大香线蕉av不卡| 青草影院天堂男人久久| 伊人久久综在合线亚洲2019 | 久久精品亚洲一区二区三区浴池| 性做久久久久久久| 精品国产一区二区三区久久蜜臀| 亚洲人成无码网站久久99热国产| 天天爽天天狠久久久综合麻豆| 88久久精品无码一区二区毛片| 97视频久久久| 精品久久久久久国产牛牛app| 99久久这里只精品国产免费| 青青青国产精品国产精品久久久久| 久久不见久久见免费影院www日本| 综合网日日天干夜夜久久| 91久久精品国产成人久久| 无码伊人66久久大杳蕉网站谷歌 | 久久精品国产只有精品66| 久久精品国产亚洲AV忘忧草18| 91久久香蕉国产熟女线看| 久久亚洲美女精品国产精品| 欧美一级久久久久久久大片| 老司机国内精品久久久久| 97精品伊人久久久大香线蕉| 欧美激情精品久久久久久| 天天综合久久久网| 免费国产99久久久香蕉| 久久精品午夜一区二区福利| 国内精品九九久久精品 | 91麻豆国产精品91久久久| 久久99国产一区二区三区| 亚洲国产成人久久综合一| 日韩精品久久久久久| 久久久久综合网久久| 国产精品99久久免费观看| 国产精品久久久久久福利漫画| 人妻精品久久久久中文字幕69| 久久AV高清无码| 国产精品视频久久| 国产精久久一区二区三区|