2017.12.21 有用的网址、AppCan iPhone适配问题、将方法作为方法的参数、处理字符串、DataTable

第一组:杨昊 分享几个有用的网址

前端电子书籍,可能有的下载不了,但是很全:
http://www1.qdfuns.com/feres.php?do=picture&listtype=book

JS简单总结,Demo形式的:
http://blog.csdn.net/luanpeng825485697/article/details/76692505

一份英文文档,各种API:
http://devdocs.io/

最后一个,一份学习Js的过程参考,送给想学JS又迷茫的你:
https://www.zhihu.com/question/19713563


第二组:赵彩凤 AppCan iPhone适配问题(分辨率区别机型,解决老年机效果)

appcan.use("detect", function($, detect) {
    if (detect.os.ios) {
        var viewport = document.getElementsByName("viewport");
        var scale = window.devicePixelRatio ? (1 / window.devicePixelRatio) : 1;
        $("[name='viewport']").attr("content", "width=device-width,target-densitydpi=device-dpi,initial-scale=" + scale + ", minimum-scale=" + scale + ", maximum-scale=" + scale);
        var fontsize = $("body").css("font-size");
        var px=window.screen.width * window.devicePixelRatio;
        if(px==640||px==1125)//iphone5,iphone5s,iphone5c,iphone se||iPhone X
        {
             $("body").css("font-size", parseInt(fontsize) + "px");
        }
        else{//其他
             $("body").css("font-size", parseInt(fontsize)*window.devicePixelRatio + "px");
        }
    }
})

//日期推后n个月

function addmulMonth(dtstr, n) {
     var s = dtstr.split("/");
     var yy = parseInt(s[0]);
     var mm = parseInt(s[1]) - 1;
     var dd = parseInt(s[2]);
     var dt = new Date(yy, mm, dd);
     dt.setMonth(dt.getMonth() + n);
     if ((dt.getYear() * 12 + dt.getMonth()) > (yy * 12 + mm + n)) {
        dt = new Date(dt.getYear(), dt.getMonth(), 0);
    }
     return dt.toLocaleDateString();
}

第三组:吴景霞 将方法作为方法的参数

来看下面这两个最简单的方法,它们在屏幕上输出一句问候的话语:

public void GreetPeople(string name) {
    // 做某些额外的事情,比如初始化之类,此处略
    EnglishGreeting(name);
}
public void EnglishGreeting(string name) {
    Console.WriteLine("Morning, " + name);
}

GreetPeople用于向某人问好,当我们传递代表某人姓名的name参数,比如说“Jimmy”,进去的时候,在这个方法中,将调用EnglishGreeting方法,再次传递name参数,EnglishGreeting则用于向屏幕输出 “Morning, Jimmy”。

现在假设这个程序需要进行全球化,哎呀,不好了,我是中国人,我不明白“Morning”是什么意思,怎么办呢?好吧,我们再加个中文版的问候方法:

public void ChineseGreeting(string name){
    Console.WriteLine("早上好, " + name);
}

这时候,GreetPeople也需要改一改了,不然如何判断到底用哪个版本的Greeting问候方法合适呢?在进行这个之前,我们最好再定义一个枚举作为判断的依据:

public enum Language{
    English, Chinese
}


public void GreetPeople(string name, Language lang){
    //做某些额外的事情,比如初始化之类,此处略
    swith(lang){
        case Language.English:
           EnglishGreeting(name);
           break;
       case Language.Chinese:
           ChineseGreeting(name);
           break;
    }
}

OK,尽管这样解决了问题,但我不说大家也很容易想到,这个解决方案的可扩展性很差,如果日后我们需要再添加韩文版、日文版,就不得不反复修改枚举和GreetPeople()方法,以适应新的需求。

后续更多精彩详情见文档


第四组:傅云 Table中处理字符串过长的办法

Table中显示的字符串过长的处理办法:有时显示在前端的字符串过长,这时可以通过字符串剪切的方法进行处理。

image.png

<td title="<%=dayWork.MpDp_CardTitle%>"><%=dayWork.MpDp_CardTitle.Length>15? dayWork.MpDp_CardTitle.Substring(0,14)+"...": dayWork.MpDp_CardTitle %></td>
将title设置为未截取的字符串,这时将鼠标移动至字符串时就会显示所有的值。在正式的显示内容中,将字符串进行截取。


第五组:王颢 DataTable和KeyDown、KeyPress、KeyUp事件以及KeyCode、KeyData、KeyValue、KeyChar属性

1. DataTable
  • 添加引用
    using System.Data;

  • 创建表

    • //创建一个空表
      DataTable dt = new DataTable();

    • //创建一个名为"Table_New"的空表
      DataTable dt = new DataTable("Table_New");

  • 创建列

    • //1.创建空列
      DataColumn dc = new DataColumn();
      dt.Columns.Add(dc);

    • //2.创建带列名和类型名的列(两种方式任选其一)
      dt.Columns.Add("column0", System.Type.GetType("System.String"));
      dt.Columns.Add("column0", typeof(String));

    • //3.通过列架构添加列
      DataColumn dc = new DataColumn("column1",System.Type.GetType("System.DateTime"));
      DataColumn dc = new DataColumn("column1", typeof(DateTime));
      dt.Columns.Add(dc);

  • 创建行

    • //1.创建空行
      DataRow dr = dt.NewRow();
      dt.Rows.Add(dr);

    • //2.创建空行
      dt.Rows.Add();

    • //3.通过行框架创建并赋值
      dt.Rows.Add("张三",DateTime.Now);//Add里面参数的数据顺序要和dt中的列的顺序对应

    • //4.通过复制dt2表的某一行来创建
      dt.Rows.Add(dt2.Rows[i].ItemArray);

  • 赋值和取值

    • //新建行的赋值
      DataRow dr = dt.NewRow();
      dr[0] = "张三";//通过索引赋值
      dr["column1"] = DateTime.Now; //通过名称赋值

    • //对表已有行进行赋值
      dt.Rows[0][0] = "张三"; //通过索引赋值
      dt.Rows[0]["column1"] = DateTime.Now;//通过名称赋值

    • //取值
      string name=dt.Rows[0][0].ToString();
      string time=dt.Rows[0]["column1"].ToString();

  • 筛选行

    • //选择column1列值为空的行的集合
      DataRow[] drs = dt.Select("column1 is null");

    • //选择column0列值为"李四"的行的集合
      DataRow[] drs = dt.Select("column0 = '李四'");

    • //筛选column0列值中有"张"的行的集合(模糊查询)
      DataRow[] drs = dt.Select("column0 like '张%'");//如果的多条件筛选,可以加 and 或 or

    • //筛选column0列值中有"张"的行的集合并按column1降序排序
      DataRow[] drs = dt.Select("column0 like '张%'", "column1 DESC");

  • 删除行

    • //使用DataTable.Rows.Remove(DataRow)方法
      dt.Rows.Remove(dt.Rows[0]);

    • //使用DataTable.Rows.RemoveAt(index)方法
      dt.Rows.RemoveAt(0);

    • //使用DataRow.Delete()方法
      dt.Row[0].Delete();
      dt.AcceptChanges();

  • //-----区别和注意点-----

    • //Remove()和RemoveAt()方法是直接删除

    • //Delete()方法只是将该行标记为deleted,但是还存在,还可DataTable.RejectChanges()回滚,使该行取消删除。

    • //用Rows.Count来获取行数时,还是删除之前的行数,需要使用DataTable.AcceptChanges()方法来提交修改。

    • //如果要删除DataTable中的多行,应该采用倒序循环DataTable.Rows,而且不能用foreach进行循环删除,因为正序删除时索引会发生变化,程式发生异常,很难预料后果。
      for (int i = dt.Rows.Count - 1; i >= 0; i--)
      {
        dt.Rows.RemoveAt(i);
      }

  • 复制表

    • //复制表,同时复制了表结构和表中的数据
      DataTable dtNew = new DataTable();
      dtNew = dt.Copy();

    • //复制表

DataTable dtNew = dt.Copy();  //复制dt表数据结构
dtNew.Clear()  //清空数据
for (int i = 0; i < dt.Rows.Count; i++)
{
    if (条件语句)
    {
         dtNew.Rows.Add(dt.Rows[i].ItemArray);  //添加数据行
    }
}

//克隆表,只是复制了表结构,不包括数据

DataTable dtNew = new DataTable();
dtNew = dt.Clone();

//如果只需要某个表中的某一行

DataTable dtNew = new DataTable();
dtNew = dt.Copy();
dtNew.Rows.Clear();//清空表数据
dtNew.ImportRow(dt.Rows[0]);//这是加入的是第一行
  • 表排序
    DataTable dt = new DataTable();//创建表
    dt.Columns.Add("ID", typeof(Int32));//添加列
    dt.Columns.Add("Name", typeof(String));
    dt.Columns.Add("Age", typeof(Int32));
    dt.Rows.Add(new object[] { 1, "张三" ,20});//添加行
    dt.Rows.Add(new object[] { 2, "李四" ,25});
    dt.Rows.Add(new object[] { 3, "王五" ,30});
    DataView dv = dt.DefaultView;//获取表视图
    dv.Sort = "ID DESC";//按照ID倒序排序
    dv.ToTable();//转为表
2. KeyDown、KeyPress、KeyUp事件以及KeyCode、KeyData、KeyValue、KeyChar属性
  • KeyDown
    //发生顺序:KeyDown->KeyPress->KeyUp
    //所有的参数的各种信息都在Keys里自带=>自己查看
    //KeyCode、KeyData、KeyValue对于字母键只记录大写的值
    //没有KeyChar
    //必须先将KeyPreview的属性设置为true
         private void Form1_KeyDown(object sender, KeyEventArgs e)
         {
             if (e.Alt && e.Control && e.KeyCode == Keys.F2) 
             {
                 MessageBox.Show("You press the Alt and Ctrl and F2 buttons!");
             }
             if (e.KeyData == Keys.Up) 
             {
                 MessageBox.Show("You press the Up buttons!");
             }
             if (e.KeyValue == 27) 
             {
                 MessageBox.Show("You press the Esc buttons!");
             }             
         }
  • KeyPress

//只能返回一个字符的ASCII码
//不能处理功能键、编辑键、组合键
//KeyChar能区分大小写
//KeyChar字存在于KeyPress中

         private void Form1_KeyPress(object sender, KeyPressEventArgs e)
         {
             if (e.KeyChar == 65)
             {
                 MessageBox.Show("You press the A buttons!");
             }
             if (e.KeyChar == 97)
             {
                 MessageBox.Show("You press the a buttons!");
             }
             //KeyChar是不区分数字是否在大小哪个键盘的
             if (e.KeyChar == 48)
             {
                 MessageBox.Show("You press the 0 buttons!");
             }
         }
  • KeyUp
    //没有KeyChar
         private void Form1_KeyUp(object sender, KeyEventArgs e)
         {
             //与KeyDown相似
             //小键盘的数字0
             if (e.KeyValue == 96)
             {
                 MessageBox.Show("You press the 0 buttons in keypad!");
             }
             //小键盘的数字0
             if (e.KeyCode == Keys.NumPad0)
             {
                 MessageBox.Show("You press the 0 buttons in keypad!");
             }
             //主键盘的数字0
             if (e.KeyCode == Keys.D0)
             {
                 MessageBox.Show("You press the 0 buttons in primary keyboard!");
             }
 
         }

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,902评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,037评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,978评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,867评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,763评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,104评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,565评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,236评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,379评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,313评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,363评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,034评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,637评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,719评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,952评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,371评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,948评论 2 341

推荐阅读更多精彩内容