delegate实现Javascript的each方法

C#如何用delegate实现Javascript的each方法

  C#中有很多易混淆的关键词,例如delegate,Func, Action和 Predicate。Func, Action和 Predicate本质上都是delegate,下面看一下delegate概念。

1 delegate概念

  delegate本质上就是一个指向函数的指针,可以指向不同的函数,只要函数的签名和代理一致即可。

2 delegate应用

  其实Func, Action, Predicate等都是delegate,只是特殊的delegate而已。delegate的巧妙应用,可以大大简化代码和提高灵活性。下面有一段Javascript代码,JS中经常使用数组的each方法来遍历数组并对其进行处理,如下所示:

1  var arr = [ "one", "two", "three", "four"];
2  $.each(arr, function(){
3     alert(this);
4  });
5 //上面这个each输出的结果分别为:one,two,three,four

  那么在C#中如何通过delegate来定义一个数组each方法呢,可以通过传入方法来实现灵活的逻辑处理,静态ListEx类下有一个静态的Each方法,定义如下:

 1 public static T[] Each<T>(T[] source, Func<T, T> function)
 2 {
 3
 4     T[] ret =new T[source.Length];
 5     int i = 0;
 6     foreach (T item in source)
 7     {
 8         ret[i]=function(item);
 9         i++;
10     }
11     return ret;
12 }

  那么我们可以定义一个字符串数组,并定义一个delegate作为函数参数进行传入,调用ListEx.Each方法:

1 var arr =new string[]{ "one", "two", "three", "four"};
2 var newArr= ListEx.Each<string>(arr,delegate(string x){
3     x=x+"_do";
4     return x;
5 });

  当然可以用表达式进行简化:

1 var newArr2 = ListEx.Each<string>(newArr, (string x) => x = x + "_do");

 我们也可以定义一个Where方法来过滤数组:

 1 public static IList<T> Find<T>(IList<T> source, Predicate<T> predicate)
 2 {
 3     List<T> ret = new List<T>();
 4     foreach (T item in source)
 5     {
 6         if (predicate(item))
 7         {
 8             ret.Add(item);
 9         }
10     }
11     return ret;
12 }
13 public static T[] Where<T>(T[] source, Predicate<T> predicate)
14 {
15     IList<T> list=source.ToList<T>();
16     IList<T> retList= Find<T>(list, predicate);
17     return retList.ToArray<T>();
18 }

  调用如下:

1 var newArr3 = ListEx.Where<string>(arr, x => x == "two");

3 区别概述

Func是必须指定返回值的代理;

 Action为返回值为void的代理;

 Predicate为返回值为bool的代理;

时间: 2024-10-10 07:17:55

delegate实现Javascript的each方法的相关文章

C#如何用delegate实现Javascript的each方法

C#中有很多易混淆的关键词,例如delegate,Func, Action和 Predicate.Func, Action和 Predicate本质上都是delegate,下面看一下delegate概念. 1 delegate概念 delegate本质上就是一个指向函数的指针,可以指向不同的函数,只要函数的签名和代理一致即可. 2 delegate应用 其实Func, Action, Predicate等都是delegate,只是特殊的delegate而已.delegate的巧妙应用,可以大大简

html,JavaScript调用winfrom方法

---恢复内容开始--- 目的: 在动画上面添加点击事件,通过JavaScript调用winfrom方法 1.创建一个页面 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; usin

Javascript 常用扩展方法

这篇文章纯粹是为了保存这些方法,供以后翻阅,其实一直保存在 evernote 里面,但觉得还是放到对的地方会好点. 现在收录的很少,希望以后会慢慢增多. 数组扩展 contains,remove 扩展 1 function ArrayContains(array, obj) { 2 for (var i = 0; i < array.length; i++) { 3 if (array[i] === obj) { 4 return true ; 5 } 6 } 7 return false ;

[13年迁移]javascript 的join(&quot;&quot;)方法,把数组变成统一字符串,用来写长的输出字符串

javascript 的join("")方法,把数组变成统一字符串,用来写长的参数字符串    function m(a) {        var b = ["<table class='DynarchCalendar-topCont'", j, "><tr><td>", "<div class='DynarchCalendar'>", e ? "<a clas

详解JavaScript的splice()方法

在javascript中splice()方法,是一个很强的数组方法,它有多种用法.splice()主要用途是向数组的中部插入项. 有如下3种方式:删除--可以删除任意数量的项,只需要指定2个参数:要删除的第一项的位置和要删除项的项数.例如,splice(0,2)会删除数组中的前两项.插入--可以向指定位置插入任意数量的项,只需要提供3个参数:骑士位置.0(要删除的项数)和要插入的项.如果要插入多个项,可以再传入第四.第五,一直任意多个项.例如,splice(2,1,"red",&quo

javascript数组原型方法

1.javascript数组原型方法. 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>jstest</title> 6 </head> 7 <body> 8 <script> 9 var arr = ["1","2&q

JavaScript数组sort()方法小结

sort语法:arrayObject.sort(sortby):参数sortby可选.规定排序顺序.必须是函数. 由于sort方法是先将数组元素转换为字符串进行比较,根据字符串首字符的ASCII码排序进行比较,所以有时候不能满足我们对数组数字集合的排序要求,但是sort()方法可以采用函数,利用冒泡法对数组进行排序,我个人的理解是如果要对其进行排序给定函数有以下两种格式: Array.sort(function(a,b){ a-b; }) 此种方法实现由小到大排序. Array.sort(fun

两种动态加载JavaScript文件的方法

两种动态加载JavaScript文件的方法 第一种便是利用ajax方式,第二种是,动静创建一个script标签,配置其src属性,经过把script标签拔出到页面head来加载js,感乐趣的网友可以看下 动态加载script到页面大约有俩方法 第一种便是利用ajax方式,把script文件代码从背景加载到前台,而后对加载到的内容经过eval()实施代码.第二种是,动静创建一个script标签,配置其src属性,经过把script标签插入到页面head来加载js,相当于正在head中写了一个<sc

javascript的shift()方法

shift()方法的定义和用法:此方法返回并删除数组的第一个元素.注:返回值是原数组的第一个元素.点击可参阅数组更多属性和方法.语法结构: arrayObject.shift() 实例代码: var a = [1,2,3]; console.log(a.shift()); 原文地址是:javascript的shift()方法一章节.