ASP.NET项目申报系统-4.20~4.27总结

4.20

在GridView的RowDataBound事件中判断是否为数据列的语句为:
if (e.Row.RowType == DataControlRowType.DataRow)//判断数据列的语句
写成其他的都不行。


动态绑定GridView中HyperLink的NavigateUrl:

//前台页面控件
<asp:HyperLinkField DataTextField="ProjName" HeaderText="项目全称" NavigateUrl="a.aspx">
                <HeaderStyle Width="20%" />
                <ItemStyle Width="20%" CssClass="content" />
                </asp:HyperLinkField> 

//后台事件处理函数
protected void GridViewProjView_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)//判断数据列的语句
        {
            HyperLink link = (HyperLink)e.Row.Cells[2].Controls[0];
            if (e.Row.Cells[7].Text == "未上报")
            {
                link.NavigateUrl = "ProjInfo.aspx?projid=" + e.Row.Cells[1].Text;
            }
            else
            {
                link.NavigateUrl = "ProjInfo2.aspx?projid=" + e.Row.Cells[1].Text;
            }
            e.Row.Cells[3].ToolTip = e.Row.Cells[3].Text;
            e.Row.Cells[4].ToolTip = e.Row.Cells[4].Text;
            e.Row.Cells[5].ToolTip = e.Row.Cells[5].Text;
            e.Row.Cells[7].ToolTip = e.Row.Cells[7].Text;
        }
    }

4.22

在VS下用正则表达式进行查找和替换,会很方便。

在vs中没有\w \d \s这类的正则表达式,所以用到的时候尽量用其他方式表示,比如\d写成[0-9];vs中空格直接打一个空格就行,不用\s表示。
[,],<,>,{,},(,)等等,这些都是特殊含义的字符,需要前面加转义字符才能匹配这些字符本身,例如 \[ 匹配 [ 。
MSDN上有完整的信息,其中包括vs复制替换中的一些特殊符号。

查找内容:Label{.*}Label{Proj[^Y].*}Label
替换为:TextBox\1TextBox\2TextBox

<td align="center" width="10%">
<asp:Label ID="LabelProjYear1" runat="server" Text=""></asp:Label>
</td>
<td align="center" width="20%">
<asp:Label ID="LabelProjBegin1" runat="server" Text=""></asp:Label>
</td>
<td align="center" width="20%">
<asp:Label ID="LabelProjEnd1" runat="server" Text=""></asp:Label>
</td>
替换成了
<td align="center" width="10%">
<asp:Label ID="LabelProjYear1" runat="server" Text=""></asp:Label>
</td>
<td align="center" width="20%">
<asp:TextBox ID="TextBoxProjBegin1" runat="server" Text=""></asp:TextBox>
</td>
<td align="center" width="20%">
<asp:TextBox ID="TextBoxProjEnd1" runat="server" Text=""></asp:TextBox>
</td>

查找内容:{ProjBegin}{[0-9]+}{".*""}
替换为:\1\2\3 οnchange="changeProjYear(\2)"

<asp:TextBox ID="TextBoxProjBegin1" runat="server" Text=""></asp:TextBox>
替换为:
<asp:TextBox ID="TextBoxProjBegin1" runat="server" Text="" οnchange="changeProjYear(1)"></asp:TextBox>

 

javascript中的substring(int a,int b)是取从第a个字符到第b个字符(不包括第b个字符)的子串,第二参数可选,无此参数表示到结尾。
C#中的Substring(int a,int b)是取从第a个字符开始,长度为b个字符的子串,同样第2个参数可选,无此参数表明到结尾。

 

要改变Label(转化成span),在客户端没有value属性的控件,用document.getElementById('<%=ControlID.ClientID%>').innerText = 'value'
innerHtml可以代替innerText。button在客户端有value属性,直接使用该属性,不要使用innerText或innerHtml,否则会出错或者修改不成功。

 

GridView中的HyperLink(或HyperLinkField,它实际也是转化成HyperLink),在后台获取它的内容,
不能使用GridViewUsrManage.Rows[i].Cells[1].Text,而应使用
HyperLink link=(HyperLink)GridViewUsrManage.Rows[i].Cells[1].Controls[0]; ...=link.Text;

 

4.23

服务器控件,visible设置成false之后,在浏览器端就不出现该控件了;想隐藏控件,在服务器端不进行修改,在客户端onload里获取该控件,然后设置其style.display="none";
或者,在前台,它所在的td里面写style="display:none"

 

4.24

C#中动态添加Table中的行:

//添加引用
using System.Web.UI.HtmlControls;

private void CreateTableRow(News news,int range)
    {
        for (int i = 1; i <= range; i++)
        {
            HtmlTableCell cell1 = new HtmlTableCell();
            cell1.InnerHtml = i.ToString();//序号
            cell1.Style.Add("text-align", "center");
            HtmlTableCell cell2 = new HtmlTableCell();
            cell2.InnerHtml = GetAttach(news, i);//附件名称
            cell2.Style.Add("text-align", "center");
            HtmlTableCell cell3 = new HtmlTableCell();
            Button buttondel = new Button();
            buttondel.ID = "ButtonDel" + i.ToString();
            buttondel.Text = "删除";
            if (news.NewsEditor != Convert.ToInt32(Session["UsrID"]))//仅能在这里disable,在pageload里面不行
            {
                buttondel.Enabled = false;
            }
            buttondel.OnClientClick = "return confirm('确定删除此附件?');";
            cell3.Controls.Add(buttondel);//删除按钮
            buttondel.Click += new EventHandler(ButtonDel_Click);
            cell3.Style.Add("text-align", "center");
            HtmlTableRow row = new HtmlTableRow();
            row.Cells.Add(cell1);
            row.Cells.Add(cell2);
            row.Cells.Add(cell3);
       //FileTable是要添加到的table的id,该table必须添加runat='server'属性,才能在后台获取到
            FileTable.Rows.Insert(i, row);
        }
    }

//获取指定的附件名称
private string GetAttach(News news,int n)
    {
        string part="";
        switch (n)
        {
            case 1: part = news.NewsAttach1; break;
            case 2: part = news.NewsAttach2; break;
            case 3: part = news.NewsAttach3; break;
            case 4: part = news.NewsAttach4; break;
            case 5: part = news.NewsAttach5; break;
            case 6: part = news.NewsAttach6; break;
            case 7: part = news.NewsAttach7; break;
            case 8: part = news.NewsAttach8; break;
            case 9: part = news.NewsAttach9; break;
            case 10: part = news.NewsAttach10; break;
            case 11: part = news.NewsAttach11; break;
            case 12: part = news.NewsAttach12; break;
            case 13: part = news.NewsAttach13; break;
            case 14: part = news.NewsAttach14; break;
            case 15: part = news.NewsAttach15; break;
            default: break;
        }
        return part;
    }

//删除按钮的事件处理函数
protected void ButtonDel_Click(object sender, EventArgs e)
{
...
}

 

用javascript,在fileupload中获取客户端文件的路径时,会出现fakepath的问题,即原本c:/usr/mashu/a.doc会显示c:/fakepath/a.doc(IE9下是如此)。这是基于客户端浏览器安全性考虑的,让js无法获取本地文件系统结构。另外,FileUpload在服务器端也无法获取客户端的文件完整url,FileUpload1.FileName只能得到文件名,而不是文件路径。
解决js获取文件路径的方法是,修改IE的设置:internet选项--安全--自定义级别--将文件上载到服务器时包含本地目录路径..--点上启用。

 

javascript中button显示与隐藏。隐藏:button1.style.display="none" 显示:button1.style.display="block"

 

要在客户端计算文件的大小需要fso = new ActiveXObject("Scripting.FileSystemObject");
这个需要ie开启一些activex的安全选项,但是开启之后,ie9会在下面提示不安全,win7下面的旗帜也会提示不安全,所以放弃在客户端js计算文件的大小了。

 

4.25

让LinkButton在客户端充当链接的作用,使用方法如下:
<asp:LinkButton ID="LinkButtonNotice" runat="server" OnClientClick="document.frames['mainFrame'].location='UnitInfo/UnitCheck.aspx';return false;">【无新消息】</asp:LinkButton>

 

js进行页面控件的遍历:

//javascript遍历页面上所有textbox,如下所示。
var anyInput=document.getElementsByTagName("input");
for(var i=0;i<anyInput.length;i++){
  if(anyInput[i].type=="text"){//把text改成checkbox就遍历了checkbox
      ...
   }
}
//遍历页面上所有select控件(服务器端为dropdownlist),如下所示。
var anySelect=document.getElementsByTagName("select");
for(var i=0;i<anySelect.length;i++){
    ...
}
//遍历checkbox的另一种实现,其中obj为前台this:
var elem = obj.form.elements;
    var flg = 0;
    for (var i = 0; i < elem.length; i++) {
        if (elem[i].type == "checkbox") {
               ...
        }
    }

支持onchange事件的 HTML 标签:<input type="text">, <select>, <textarea>

 

 

ASP.net定期删除临时文件的方法,在Global.asax里面,写如下内容:

 

//定期清除DownLoad里面的临时文件
    System.Timers.Timer deleteTmpTimer;
    void Application_Start(object sender, EventArgs e) 
    {
        // 在应用程序启动时运行的代码
        deleteTmpTimer = new System.Timers.Timer(1000 * 60 * 60 * 24); //1天,参数单位为ms
        deleteTmpTimer.Elapsed += new System.Timers.ElapsedEventHandler(OnTimeEvent_DelTempFile);
        deleteTmpTimer.Enabled = true;
    }

//清除Download文件夹里的一天之前的文件
    void OnTimeEvent_DelTempFile(object sender,System.Timers.ElapsedEventArgs e)
    {
        string deleteTime = DateTime.Now.AddDays(-1).ToString("yyMMddHHmmssff");
        string path = Server.MapPath("~/Download");
        System.IO.DirectoryInfo dirInfo = new System.IO.DirectoryInfo(path);
        if (dirInfo.Exists && dirInfo.GetFiles().Length > 0)
        {
            System.IO.FileInfo[] files = dirInfo.GetFiles();
            for (int i = 0; i < files.Length; i++)
            {
                if (files[i].Exists)
                {
                    try
                    {
                        if (files[i].Name.Substring(0, 14).CompareTo(deleteTime) < 0)
                        {
                            //标记为临时文件,并删除
                            System.IO.File.SetAttributes(path + "\\" + files[i].Name, System.IO.FileAttributes.Temporary);
                            System.IO.File.Delete(path + "\\" + files[i].Name);
                        }
                    } 
                    catch(System.IO.IOException ex)
                    {
                        throw ex;
                    }
                } 
            } 
        }

 

 

 

4.27

 

label虽然是服务器端的控件,但是不能在前台修改label的值,然后在后台取其值。
用隐藏域,隐藏域的值被JS修改过以后是可以发送到服务器的。
Label控件在客户端生成了Span标签,Span标签的内容在客户端的修改是不会发送到服务器端的。

 

javascript有lastIndexOf(searchvalue,fromindex)函数,第一个是要匹配的字符串,第二个是匹配开始的位置,可选项,无此参数表示从结尾开始。(注意大小写)
javascript有indexOf(searchvalue,fromindex)函数,第一个是要匹配的字符串,第二个是匹配开始的位置,可选项,无此参数表示从头开始。(注意大小写)

 

 

转载于:https://www.cnblogs.com/particle/archive/2012/05/03/2480200.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
react-developer-tools 4.27.4 是一个用于调试和分析 React 应用程序的工具。它是 React 生态系统中的一个重要插件,可以帮助开发者更好地理解和优化他们的应用程序。 首先,react-developer-tools 提供了一个浏览器扩展程序,可以方便地与开发工具集成。通过安装这个扩展程序,开发者可以在浏览器的开发者工具中获得专门的 React 面板,其中包含了有关应用程序中每个 React 组件的详细信息。这些信息包括组件的层次结构、props 和 state 的值以及组件更新的时间等等。通过查看这些信息,开发者可以深入了解应用程序的组件树,并在开发过程中调试和分析组件的行为。 其次,react-developer-tools 还提供了一些高级功能,以帮助开发者更好地理解和优化 React 应用程序的性能。例如,它可以显示组件的重新渲染次数,从而帮助开发者找出不必要的渲染和性能瓶颈。它还可以在组件的生命周期中显示每个阶段的时间,帮助开发者识别潜在的性能问题,并通过优化组件的更新逻辑来提高性能。 此外,react-developer-tools 还提供了一个组件搜索功能,开发者可以通过输入组件的名称或关键字来快速查找和定位组件。这对于大型应用程序的调试和分析非常有用,特别是在组件树较为复杂的情况下。 总的来说,react-developer-tools 4.27.4 是一个功能强大、方便易用的工具,能够帮助开发者更好地调试和优化 React 应用程序。无论是开发新项目还是维护现有项目,它都是一个不可或缺的辅助工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值