我正在尝试在我的应用程序中显示文本。输入是我正在接受使用FileUpload的文本文件。我必须将文本分成单词,并将每个单词分成相应的字符。然后,每个单词首先以字母方式显示,然后在一个选框中显示整个单词。
到目前为止,我已成功接受该文件。我也成功地拆分了内容。但是我对在每个字母显示后如何添加延迟毫无头绪。此外,在显示每个字符后,它必须在下一个字符出现之前消失。我尝试使用Thread.Sleep(),但它所做的就是冻结我的UI,让线程在开始时进入休眠状态,并立即显示所有内容。
等待Task.Delay()。
有人告诉我使用计时器,但我是C#编程的新手,不知道它们是如何工作的。到目前为止,这就是我所做的。第一个按钮(即Button1
)按原样显示文件的内容。第二个按钮(即Button2
)用于分割文本。
aspx.cs文件:
protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
String a = FileUpload1.FileName;
String ext = Path.GetExtension(a);
//Label1.Text = ext;
if (ext == ".txt")
{
System.IO.StreamReader reader = new System.IO.StreamReader(FileUpload1.FileContent);
string text = reader.ReadToEnd();
//Response.Write(text);
TextBox1.Text = text;
//Above section for text file
}
if (ext == ".docx" || ext == ".doc")
{
//String b = FileUpload1.PostedFile.FileName;
// Open a doc file.
string filename = Path.GetFileName(FileUpload1.FileName);
FileUpload1.SaveAs(Server.MapPath("~/") + filename);
Application application = new Application();
Document document = application.Documents.Open(Server.MapPath("~/") + filename);
// Loop through all words in the document.
int count = document.Words.Count;
for (int i = 1; i <= count; i++)
{
// Write the word.
string text = document.Words[i].Text;
//Response.Write(text);
TextBox1.Text = text;
}
// Close word file
application.Quit();
}
}
protected void Button2_Click(object sender, EventArgs e)
{
String a1 = FileUpload1.FileName;
String ext1 = Path.GetExtension(a1);
if (ext1 == ".txt")
{
System.IO.StreamReader reader = new System.IO.StreamReader(FileUpload1.FileContent);
string text = reader.ReadToEnd();
/*foreach (char c in text)
{
TextBox2.Text = c.ToString();
System.Threading.Thread.Sleep();
}*/
List<string> list = new List<string>(); //code for splitting
String[] words = text.Split();
for (int i = 0; i < words.Length; i++)
{
list.Add(words[i]);
}
foreach (string word in words)
{
Char[] letters = word.ToCharArray();
foreach (char letter in letters)
{
Response.Write("<marquee>"+letter+"</marquee>");
Response.Write("<br>");
}
Response.Write("<marquee>" + word + "</marquee>");
Response.Write("<br>");
}
}
}
答案 0 :(得分:1)
你应该使用客户端脚本而不是服务器代码...使用updatePanel .... :) 在你的aspx中:
<asp:UpdatePanel ID="updatePanel1" runat="server">
<ContentTemplate>
<div style="display:none">
<!-- Hidden Field For Storing our formatted Text -->
<asp:Literal ID="hiddenLiteral" runat="server"/></div>
<!-- a field for store Javascript -->
<asp:Literal ID="scriptLiteral" runat="server"/>
<!-- a field which use for Showing Text To User -->
<asp:Literal ID="displayLiteral" runat="server"/>
</ContentTemplate>
</asp:UpdatePane>
然后为literalValue编写一个javascript,然后更新updatePanel,如下所示:
protected void Button2_Click(object sender, EventArgs e)
{
String a1 = FileUpload1.FileName;
String ext1 = Path.GetExtension(a1);
if (ext1 == ".txt")
{
System.IO.StreamReader reader = new System.IO.StreamReader(FileUpload1.FileContent);
string text = reader.ReadToEnd();
List<string> list = new List<string>(); //code for splitting
String[] words = text.Split();
for (int i = 0; i < words.Length; i++)
{
list.Add(words[i]);
}
var textTobeShown = new List<string>();
foreach (string word in words)
{
Char[] letters = word.ToCharArray();
foreach (char letter in letters)
{
textTobeShown.Add("<marquee>"+letter+"</marquee>");
}
textTobeShown.Add("<marquee>" + word + "</marquee>");
}
//use <sep> for separating text
hiddenLiteral.text=String.Join("<sep>",textTobeShown);
//Call Our Javascript Function when updatePanel Update Fields Value
scriptLiteral.Text=String.Concat("<script> DisplayText('",hiddenLiteral.ClientID,"','",displayLiteral.ClientID,"'); </script>");
//updating our updatePanel
updatePanel1.Update();
}
}
并在你的Html(aspx)中定义一个脚本Tag这样:
<script>
function DisplayText(hiddenFieldId,textFieldId){
var hiddenValue=document.getElementById(hiddenFieldId);
var textField=document.getElementById(textFieldId);
if(!hiddenValue || !textField) {throw 'HddenField or TextField Not Find';}
var textToBeShown=hiddenValue.innerHTML.split('<sep>');
if(textToBeShown.length==0){throw 'there is nothing to show';}
var count=textToBeShown.length;
//create delay for shown Text, in 0.5secon,1second...
var delay=0.5;
//loop through text and show them, after showing each text, delay for 500ms(0.5s)
timeout([0,count], 1, function(i){
textField.innerHTML+=textToBeShown[i]+'<br />';
});
}
function timeout(range, time, callback){
var i = range[0];
callback(i);
Loop();
function Loop(){
setTimeout(function(){
i++;
if (i<range[1]){
callback(i);
Loop();
}
}, time*1000)
}
}
</script>