您好,登錄后才能下訂單哦!
asp.net中怎么利用Ajax實現文本文件靜態分頁,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
服務端部分 ,文本文件分頁的類。主要在流中處理。當然我看過網上的用</br> 關鍵字進行分頁的
using System; using System.Collections.Generic; using System.Text; using System.IO; namespace Txt { public class TxtPager { public TxtPager() { } public TxtPager(string _txtPath, int _Pagesize) { { this.txtPath = _txtPath; this.pageSize = _Pagesize; } } string txtPath;//文件路徑 int pageSize;//每頁文本行數 // int ppt;// int number; // int totalPage; #region public int TotalPage { get { if (TxtLineCount() % pageSize == 0) return TxtLineCount() / pageSize; else return TxtLineCount()/pageSize + 1; } } public int Ppt { get { return TxtLineCount(); } } public int Number { get { return number; } set { number = value; } } #endregion private int TxtLineCount() { StreamReader sr = new StreamReader(this.txtPath); string line; int count = 0; while ((line = sr.ReadLine()) != null) { //line += "fuck"; count++; } return count; } public string ReadTxtToHtml() { string line;//存放一行文字 int ptr = 0;//行計數 int ttp = 1;//分頁后的最大頁數 StreamReader sr = new StreamReader(txtPath); string htmlStr = "";//用于存放Html代碼 htmlStr += "#" + ttp + "</br>"; while ((line = sr.ReadLine()) != null) { if (ptr == pageSize) { ttp++; htmlStr += "#" + ttp + "</br>"; ttp++; htmlStr += "#" + ttp + "</br>"; ptr = 0; } htmlStr += line + "</br>"; ptr++; } htmlStr += "#" + (ttp + 1) ; //return htmlStr; if (number > ttp+1/2) { number = ttp; } //................................. string startStr = "#" + (2 * number - 1);//1 string endStr = "#" + (2 * number);//2 1---2 int startNum = htmlStr.IndexOf(startStr); int endNum = htmlStr.IndexOf(endStr); int offset = startStr.Length; return htmlStr.Substring(startNum + offset, endNum - (startNum + offset)); } } }
這里是這個類的使用方法:
這段代碼用來解釋分頁類的使用有一點不直觀,主要是寫的時候我是針對多的文件分頁的,還好我這里只需要6個而已;需要多個也可也滿足要求。
public partial class TxtPager : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { int pageSize = 40; string _path = rtPath(int.Parse(Request.QueryString["txtid"])); string path = HttpContext.Current.Server.MapPath(_path); Txt.TxtPager tp = new Txt.TxtPager(path, pageSize); int _ttpage = tp.TotalPage; if (Request.RequestType.ToString().ToLower() == "get") { Response.Write(_ttpage.ToString()); Response.End(); } if (Request.RequestType.ToLower() == "post") { //string = //前端判斷 index 是否為數字 string index = Request.QueryString["index"]; tp.Number = int.Parse(index); string context = tp.ReadTxtToHtml(); Response.Write(context); Response.End(); } } private string rtPath(int i) { string[] pathCollection = { "Test.txt" ,"tdays.txt","problem.txt","jion.txt","serve.txt","project.txt","icexplain.txt"}; return "txt/" + pathCollection[i]; } }
上面這也是為Ajax 的請求做準備的,寫的還是很粗糙的,希望高手莫扔我雞蛋
Ajax 代碼部分
<script type="text/javascript" language="javascript"> var xmlhttp; var pxmlhttp; var TotilPage; var ContectBody; function GetXmlHttpRequset() { var rtxmlHttp; try { rtxmlHttp = new XmlHttpRequset();} catch(e) { try { rtxmlHttp = new ActiveXObject("Mxxml2.XMLHTTP"); } catch(e) { try{ rtxmlHttp = new ActiveXObject("Microsoft.XMLHTTP");} catch(e) { alert("您的的瀏覽器不支持Ajax"); } } } return rtxmlHttp; } function GetPagerCount() { xmlhttp = GetXmlHttpRequset(); var url = "TxtPager.aspx?txtid=0"; try { xmlhttp.open("get",url,false); } catch(e) { return false; } xmlhttp.onreadystatechange = CountCallBack; xmlhttp.send(null); return true; } function CountCallBack() { if(xmlhttp.readyState == 4) { var count = xmlhttp.responseText; var i = 0; for(i=0 ; i<count ; i++) { var ChildDiv = document.createElement("div"); document.getElementById("Count1").appendChild( ChildDiv); ChildDiv.innerHTML = i+1; ChildDiv.setAttribute("id",i); ChildDiv.setAttribute("onclick","GetHtmlString("+(i+1)+")"); GetHtmlString(1); } } } function GetHtmlString(i) { pxmlhttp = GetXmlHttpRequset(); var Url = "TxtPager.aspx?txtid=0&index="+ i; pxmlhttp.open("post",Url,false); pxmlhttp.onreadystatechange = ContextPostBack ; pxmlhttp.send(null); } function ContextPostBack() { if(pxmlhttp.readyState == 4) { var context = pxmlhttp.responseText; document.getElementById("article").innerHTML = context; } } </script>
代碼還是很淺顯易懂的,呵呵因為我也不會寫高深的代碼。重要的我們都要動手去實踐。菜鳥們多多努力哦。做完我這個例子級會收獲很多哦。
至少當我還是個初級菜鳥的時候要是有這個例子進步會很快。
<table width="90%" border="0" cellspacing="0" cellpadding="0"> <tr> <td align="center">冰激凌制作方法大全</td> </tr> <tr> <td id="article" align="left" >td> </tr> <tr> <td id="Count1" > </td> </tr> </table>
關于asp.net中怎么利用Ajax實現文本文件靜態分頁問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。