• 笔记0608


    1,

    string和stringBuilder区别

    C# 
    String 对象是不可改变的。每次使用 System.String 类中的方法之一时,都要在内存中创建一个新的字符串对象,这就需要为该新对象分配新的空间。在需要对字符串执行重复修改的情况下,与创建新的 String对象相关的系统开销可能会非常昂贵。如果要修改字符串而不创建新的对象,则可以使用System.Text.StringBuilder 类。例如,当在一个循环中将许多字符串连接在一起时,使用 StringBuilder类可以提升性能。

    通过用一个重载的构造函数方法初始化变量,可以创建 StringBuilder 类的新实例,正如以下示例中所阐释的那样。

    设置容量和长度 
    虽然 StringBuilder 对象是动态对象,允许扩充它所封装的字符串中字符的数量,但是您可以为它可容纳的最大字符数指定一个值。此值称为该对象的容量,不应将它与当前 StringBuilder 对象容纳的字符串长度混淆在一起。例如,可以创建 StringBuilder 类的带有字符串“Hello”(长度为 5)的一个新实例,同时可以指定该对象的最大容量为 25。当修改 StringBuilder 时,在达到容量之前,它不会为其自己重新分配空间。当达到容量时,将自动分配新的空间且容量翻倍。可以使用重载的构造函数之一来指定 StringBuilder 类的容量。以下代码示例指定可以将 MyStringBuilder 对象扩充到最大 25 个空白。    
    MyStringBuilder.Capacity = 25; 

    EnsureCapacity 方法可用来检查当前 StringBuilder 的容量。如果容量大于传递的值,则不进行任何更改;但是,如果容量小于传递的值,则会更改当前的容量以使其与传递的值匹配。 

    也可以查看或设置 Length 属性。如果将 Length 属性设置为大于 Capacity 属性的值,则自动将Capacity 属性更改为与 Length 属性相同的值。如果将 Length 属性设置为小于当前 StringBuilder 对象内的字符串长度的值,则会缩短该字符串。 

    修改 StringBuilder 字符串 
    下表列出了可以用来修改 StringBuilder 的内容的方法。 

    StringBuilder.Append 将信息追加到当前 StringBuilder 的结尾。 
    StringBuilder.AppendFormat 用带格式文本替换字符串中传递的格式说明符。 
    StringBuilder.Insert 将字符串或对象插入到当前 StringBuilder 对象的指定索引处。 
    StringBuilder.Remove 从当前 StringBuilder 对象中移除指定数量的字符。 
    StringBuilder.Replace 替换指定索引处的指定字符。 

    Append 
    Append 方法可用来将文本或对象的字符串表示形式添加到由当前 StringBuilder 对象表示的字符串的结尾处。以下示例将一个 StringBuilder 对象初始化为“Hello World”,然后将一些文本追加到该对象的结尾处。将根据需要自动分配空间。 

    [C#] 
    StringBuilder MyStringBuilder = new StringBuilder("Hello World!"); 
    MyStringBuilder.Append(" What a beautiful day."); 
    Console.WriteLine(MyStringBuilder); 


    AppendFormat 
    AppendFormat 方法将文本添加到 StringBuilder 的结尾处,而且实现了 IFormattable 接口,因此可接受格式化部分中描述的标准格式字符串。可以使用此方法来自定义变量的格式并将这些值追加到StringBuilder 的后面。以下示例使用 AppendFormat 方法将一个设置为货币值格式的整数值放置到StringBuilder 的结尾。 

    [C#] 
    int MyInt = 25; 
    StringBuilder MyStringBuilder = new StringBuilder("Your total is "); 
    MyStringBuilder.AppendFormat("{0:C} ", MyInt); 
    Console.WriteLine(MyStringBuilder); 

    Insert 
    Insert 方法将字符串或对象添加到当前 StringBuilder 中的指定位置。以下示例使用此方法将一个单词插入到 StringBuilder 的第六个位置。 

    [C#] 
    StringBuilder MyStringBuilder = new StringBuilder("Hello World!"); 
    MyStringBuilder.Insert(6,"Beautiful "); 
    Console.WriteLine(MyStringBuilder); 

    Remove 
    可以使用 Remove 方法从当前 StringBuilder 中移除指定数量的字符,移除过程从指定的从零开始的索引处开始。以下示例使用 Remove 方法缩短 StringBuilder。 

    [C#] 
    StringBuilder MyStringBuilder = new StringBuilder("Hello World!"); 
    MyStringBuilder.Remove(5,7); 
    Console.WriteLine(MyStringBuilder); 

    Replace 
    使用 Replace 方法,可以用另一个指定的字符来替换 StringBuilder 对象内的字符。以下示例使用Replace 方法来搜索 StringBuilder 对象,查找所有的感叹号字符 (!),并用问号字符 (?) 来替换它们。 

    [C#] 
    StringBuilder MyStringBuilder = new StringBuilder("Hello World!"); 
    MyStringBuilder.Replace('!', '?'); 
    Console.WriteLine(MyStringBuilder);

     

    2,

    Window.ShowModalDialog使用手册

    2006-04-17 08:56 来源:CSDN 作者:leavecd 责任编辑:龙犊·yesky 评论(31)
     
     
     

    基本介绍:
             showModalDialog()                              (IE 4+ 支持)
             showModelessDialog()                         (IE 5+ 支持)
             window.showModalDialog()                 方法用来创建一个显示HTML内容的模态对话框。
             window.showModelessDialog()            方法用来创建一个显示HTML内容的非模态对话框。
    使用方法:
             vReturnValue = window.showModalDialog(sURL [, vArguments] [,sFeatures])
             vReturnValue = window.showModelessDialog(sURL [, vArguments] [,sFeatures])
    参数说明:
            sURL                --   必选参数,类型:字符串。用来指定对话框要显示的文档的URL。
            vArguments   --    可选参数,类型:变体。用来向对话框传递参数。传递的参数类型不限,包括数组等。对话框通过window.dialogArguments来取得传递进来的参数。
            sFeatures       --    可选参数,类型:字符串。用来描述对话框的外观等信息,可以使用以下的一个或几个,用分号“;”隔开。
    ----------------
    1.   dialogHeight:   对话框高度,不小于100px
    2.   dialogWidth:   对话框宽度。
    3.   dialogLeft:    离屏幕左的距离。
    4.   dialogTop:    离屏幕上的距离。
    5.   center:         { yes | no | 1 | 0 } :             是否居中,默认yes,但仍可以指定高度和宽度。
    6.   help:            {yes | no | 1 | 0 }:               是否显示帮助按钮,默认yes。
    7.   resizable:      {yes | no | 1 | 0 } [IE5+]:    是否可被改变大小。默认no。
    8.   status:         {yes | no | 1 | 0 } [IE5+]:     是否显示状态栏。默认为yes[ Modeless]或no[Modal]。
    9.   scroll:           { yes | no | 1 | 0 | on | off }:是否显示滚动条。默认为yes。

    下面几个属性是用在HTA中的,在一般的网页中一般不使用。
    10.   dialogHide:{ yes | no | 1 | 0 | on | off }:在打印或者打印预览时对话框是否隐藏。默认为no。
    11.   edge:{ sunken | raised }:指明对话框的边框样式。默认为raised。
    12.   unadorned:{ yes | no | 1 | 0 | on | off }:默认为no。


    参数传递:
    1.   要想对话框传递参数,是通过vArguments来进行传递的。类型不限制,对于字符串类型,最大为4096个字符。也可以传递对象,例如:
    -------------------------------
    parent.htm
    <script>
             var obj = new Object();
             obj.name="51js";
             window.showModalDialog("modal.htm",obj,"dialogWidth=200px;dialogHeight=100px");
    </script>
    modal.htm
    <script>
             var obj = window.dialogArguments
             alert("您传递的参数为:" + obj.name)
    </script>
    -------------------------------
    2.   可以通过window.returnValue向打开对话框的窗口返回信息,当然也可以是对象。例如:
    ------------------------------
    parent.htm
    <script>
             str =window.showModalDialog("modal.htm",,"dialogWidth=200px;dialogHeight=100px");
             alert(str);
    </script>
    modal.htm
    <script>
             window.returnValue="http://homepage.yesky.com";
    </script>

    常见技巧:

    一、怎样才让在showModalDialog和showModelessDialog的超连接不弹出新窗口?
      在被打开的网页里加上<base target="_self">就可以了。这句话一般是放在<head>之间的。

    二、怎样才刷新showModalDialog和showModelessDialog里的内容?
      在showModalDialog和showModelessDialog里是不能按F5刷新的,又不能弹出菜单。这个只能依靠

    javascript了,以下是相关代码:

    <body onkeydown="if (event.keyCode==116){reload.click()}">
    <a id="reload" href="filename.htm" style="display:none">reload...</a>

      将filename.htm替换成网页的名字然后将它放到你打开的网页里,按F5就可以刷新了,注意,这个要

    配合<base target="_self">使用,不然你按下F5会弹出新窗口的。

    三、如何用javascript关掉showModalDialog(或showModelessDialog)打开的窗口。
      <input type="button" value="关闭" onclick="window.close()">
      也要配合<base target="_self">,不然会打开一个新的IE窗口,然后再关掉的。

    四、Math.random与showModalDialog。

       当你设置的弹出网页固定时(如上面的"modal.htm"页面),ie很可能到临时文件区,下载上次产生的该页面(openPage.html),而没有重新加载,

       对于动态加载的页面来说,这样往往产生误会,如没有及时更新数据,也就更不利于开发者测试。所以,你可以采用如下方式:

          var strPage = “/medal.htm?random="+Math.random();

       这样每次产生的strPage是不一样的,原因也就不言自明了。

    javascript中showModalDialog和showModelessDialog的使用

    javascript中showModalDialog和showModelessDialog的使用

    javascript中showModalDialog和showModelessDialog区别 

    1.  showModalDialog和showModelessDialog的异同

       同:两者弹出的窗体不能刷新

       异:前者是模态窗口,始终获得焦点;后者是非模态窗口,只不过弹出一个页面,还可以操作父窗口。

    2.   关闭showModalDialog和showModelessDialog弹出的窗口

         <INPUT type="button" value="ButtonClick" onclick="self.close();">

    3.   怎样才让在showModalDialog和showModelessDialog的弹出新窗口里操作button,不弹出新窗口?

         在<head>和</head>之间加<base target="_self">

    4.     showModalDialog的返回值

    参照例子:

    t1.html:

    <script language="javascript">
    function showpage()
    {
    alert(showModalDialog("t2.html"));
    }
    </script>
    <input type="button" value="getval" onClick="showpage();">

    t2.html
    <HTML>
    <HEAD>
    <Script language="javascript">
    <
    function SetVal()
    {
       returnValue="abc";
       close();
    }
    //-->
    </Script>
    </HEAD>
    <BODY>  
    <input type="button" value="Btn1" onClick="SetVal();">
    </BODY>
    </HTML>


    基本介绍:
    showModalDialog() (IE 4+ 支持)
    showModelessDialog() (IE 5+ 支持)
    window.showModalDialog()方法用来创建一个显示HTML内容的模态对话框。
    window.showModelessDialog()方法用来创建一个显示HTML内容的非模态对话框。

    使用方法:
    vReturnValue = window.showModalDialog(sURL [, vArguments] [,sFeatures])
    vReturnValue = window.showModelessDialog(sURL [, vArguments] [,sFeatures])

    参数说明:
    sURL--必选参数,类型:字符串。用来指定对话框要显示的文档的URL。
    vArguments--可选参数,类型:变体。用来向对话框传递参数。传递的参数类型不限,包括数组等。对话框通过window.dialogArguments来取得传递进来的参数。
    sFeatures--可选参数,类型:字符串。用来描述对话框的外观等信息,可以使用以下的一个或几个,用分号“;”隔开。
    1.dialogHeight :对话框高度,不小于100px,IE4中dialogHeight 和 dialogWidth 默认的单位是em,而IE5中是px,为方便其见,在定义modal方式的对话框时,用px做单位。
    2.dialogWidth: 对话框宽度。
    3.dialogLeft: 离屏幕左的距离。
    4.dialogTop: 离屏幕上的距离。
    5.center: {yes | no | 1 | 0 }:窗口是否居中,默认yes,但仍可以指定高度和宽度。
    6.help: {yes | no | 1 | 0 }:是否显示帮助按钮,默认yes。
    7.resizable: {yes | no | 1 | 0 } [IE5+]:是否可被改变大小。默认no。
    8.status: {yes | no | 1 | 0 } [IE5+]:是否显示状态栏。默认为yes[ Modeless]或no[Modal]。
    9.scroll:{ yes | no | 1 | 0 | on | off }:指明对话框是否显示滚动条。默认为yes。
    下面几个属性是用在HTA中的,在一般的网页中一般不使用。
    10.dialogHide:{ yes | no | 1 | 0 | on | off }:在打印或者打印预览时对话框是否隐藏。默认为no。
    11.edge:{ sunken | raised }:指明对话框的边框样式。默认为raised。
    12.unadorned:{ yes | no | 1 | 0 | on | off }:默认为no。

    参数传递:
    1.要想对话框传递参数,是通过vArguments来进行传递的。类型不限制,对于字符串类型,最大为4096个字符。也可以传递对象,例如:

    <script>
    var obj = new Object();
    obj.name="ttop";
    window.showModalDialog("test.htm",obj,"dialogWidth=200px;dialogHeight=100px");
    </script>
    test.htm
    <script>
    var obj = window.dialogArguments
    alert("您传递的参数为:" + obj.name)
    </script>

    2.可以通过window.returnValue向打开对话框的窗口返回信息,当然也可以是对象。例如:

    <script>
    str =window.showModalDialog("test.htm",,"dialogWidth=200px;dialogHeight=100px");
    alert(str);
    </script>
    test.htm
    <script>
    window.returnValue="/";
    </script>


    一、showModalDialog和showModelessDialog有什么不同?
      showModalDialog:被打开后就会始终保持输入焦点。除非对话框被关闭,否则用户无法切换到主窗口。类似alert的运行效果。
      showModelessDialog:被打开后,用户可以随机切换输入焦点。对主窗口没有任何影响(最多是被挡住一下而以。:P)

    二、怎样才让在showModalDialog和showModelessDialog的超连接不弹出新窗口?
      在被打开的网页里加上<base target="_self">就可以了。这句话一般是放在<html>和<body>之间的。

    三、怎样才刷新showModalDialog和showModelessDialog里的内容?
      在showModalDialog和showModelessDialog里是不能按F5刷新的,又不能弹出菜单。这个只能依靠javascript了,以下是相关代码:

    <body onkeydown="if (event.keyCode==116){reload.click()}">
    <a id="reload" href="filename.htm" style="display:none">reload...</a>

      将filename.htm替换成网页的名字然后将它放到你打开的网页里,按F5就可以刷新了,注意,这个要配合<base target="_self">使用,不然你按下F5会弹出新窗口的。

    四、如何用javascript关掉showModalDialog(或showModelessDialog)打开的窗口。
      <input type="button" value="关闭" onclick="window.close()">
      也要配合<base target="_self">,不然会打开一个新的IE窗口,然后再关掉的。

    五、showModalDialog和showModelessDialog数据传递技巧。
      (作者语:本来想用一问一答形式来写的,但是我想不出这个怎么问,所以只好这样了。)
      这个东西比较麻烦,我改了好几次了不是没办法说明白(语文水平越来越差了),只好用个例子说明了。
      例子:
        现在需要在一个showModalDialog(或showModelessDialog)里读取或设置一个变量var_name

          一般的传递方式:
            window.showModalDialog("filename.htm",var_name)
            //传递var_name变量
          在showModalDialog(或showModelessDialog)读取和设置时:
            alert(window.dialogArguments)//读取var_name变量
            window.dialogArguments="oyiboy"//设置var_name变量
        这种方式是可以满足的,但是当你想在操作var_name同时再操作第二个变理var_id时呢?就无法再进行操作了。这就是这种传递方式的局限性。
        
          以下是我建议使用的传递方式:
            window.showModalDialog("filename.htm",window)
            //不管要操作什么变量,只直传递主窗口的window对象
          在showModalDialog(或showModelessDialog)读取和设置时:
            alert(window.dialogArguments.var_name)//读取var_name变量
            window.dialogArguments.var_name="oyiboy"//设置var_name变量

            同时我也可以操作var_id变量
            alert(window.dialogArguments.var_id)//读取var_id变量
            window.dialogArguments.var_id="001"//设置var_id变量

            同样还可以对主窗口的任何对象进行操作,如form对象里的元素。
            window.dialogArguments.form1.index1.value="这是在设置index1元素的值"

    六、多个showModelessDialog的相互操作。
      以下代码的主要作用是在一个showModelessDialog里移动别一个showModelessDialog的位置。

      主文件的部份js代码。
      var s1=showModelessDialog('控制.htm',window,"dialogTop:1px;dialogLeft:1px") //打开控制窗口
      var s2=showModelessDialog('about:blank',window,"dialogTop:200px;dialogLeft:300px")  //打开被控制窗口

      控制.htm的部份代码。
      <script>
        //操作位置数据,因为窗口的位置数据是"xxxpx"方式的,所以需要这样的一个特殊操作函数。
    function countNumber(A_strNumber,A_strWhatdo)
    {
       A_strNumber=A_strNumber.replace('px','')
       A_strNumber-=0
       switch(A_strWhatdo)
       {
       case "-":A_strNumber-=10;break;
       case "+":A_strNumber+=10;break;
       }
       return A_strNumber + "px"
    }
      </script>
      <input type="button" onclick="window.dialogArguments.s2.dialogTop=countNumber(window.dialogArguments.s2.dialogTop,'-')" value="上移">
      <input type="button" onclick="window.dialogArguments.s2.dialogLeft=countNumber(window.dialogArguments.s2.dialogLeft,'-')" value="左移">
      <input type="button" onclick="window.dialogArguments.s2.dialogLeft=countNumber(window.dialogArguments.s2.dialogLeft,'+')" value="右移">
      <input type="button" onclick="window.dialogArguments.s2.dialogTop=countNumber(window.dialogArguments.s2.dialogTop,'+')" value="下移">

      以上关键部份是:
        窗口命名方式:var s1=showModelessDialog('控制.htm',window,"dialogTop:1px;dialogLeft:1px")
        变量访问方式:window.dialogArguments.s2.dialogTop

      这个例子只是现实showModelessDialog与showModelessDialog之间的位置操作功能,通过这个原理,在showModelessDialog之间相互控制各自的显示页面,传递变量和数据等。这要看各位的发挥了。

     3,

    想调用后台按钮的事件,不用AJAX,可以使用一种变通的方法。
    比如你一个前台HTML控件 ID=ctl吧,在这里控件的onclick事件中绑定下面的函数.同时假定已存在一个ID=btnTest的服务器控件(该控件有后台Click事件)
    <input id='ctl' type='button' onclick='callOtherBtnEvent();' />
    function callOtherBtnEvent(){
    document.getElementById('<%btnTest.ClientID%>').click();
    }
    后台public void btnTest_Click(object sender,EventArgs e)
    {
    Response.Write("<script>alert('调用了后台事件')</script>");
    }

    4, runat="server" 
  • 相关阅读:
    linux下面发布80端口的服务
    visio 安装
    SSH进行登录远程主机,实验室网站,项目
    论文遇到的问题
    ubuntu设置目录容量大小
    ubuntu 磁盘分区
    SpringBoot打成的jar包发布,shell关闭之后一直在服务器运行
    docker的安装,使用
    多线程下载文件,ftp文件服务器
    抖音红人,
  • 原文地址:https://www.cnblogs.com/jonson1126/p/3125645.html
Copyright © 2020-2023  润新知