![]() | 1 family 2014-01-23 10:43:16 +08:00 没有“正确”吧 “友好”就行 |
![]() | 2 dialox 2014-01-23 11:05:39 +08:00 从可读性上看,方法1比较好,可以用“key”来描述参数的含义。另外,方法1也方便未来在接口调用的时候增加参数。 |
![]() | 3 sarices 2014-01-23 11:10:13 +08:00 可以这样,默认value2参数为空,然后必须填写第一个参数,如果第一个参数为数组即表示使用数组传参数 |
![]() | 4 akira 2014-01-23 11:14:07 +08:00 参数数量多,用第一种;参数数量少,用第二种。例如只有一个参数,写key什么的就很多余了。 PS : 两种格式同时支持又不是不行。。。 |
![]() | 5 alex321 2014-01-23 11:16:26 +08:00 方法 1 是传递的数组,扩展性很好。 is_array($temp)/////// |
6 judasnow 2014-01-23 13:38:01 +08:00 倾向于第一种,便于参数合法性的检查。 |
![]() | 7 issac 2014-01-23 13:48:55 +08:00 第一种清晰,容易理解; 其实用JSON更方便; |
![]() | 8 dorentus nbsp; 2014-01-23 14:16:44 +08:00 via iPhone 没有实际场景,没法说哪种是「正确」的。 如果你不确定的话,可以自己作为自己的用户,做个小项目实际使用一下自己提供的 API 看看感受。 |
![]() | 9 picasso250 OP |
![]() | 10 otakustay 2014-01-23 16:06:21 +08:00 ![]() 个人习惯是,设计一个API,其参数分为2类。 第1类是没它不可的,这一类就直接传递,不放在array中 第2类是可有可无的,属配置项,放在array中 举个例子(Javascript): findUserById(id, { includeDisabledUsers: true }) 这个方法既然叫ById了,id显然是要提供的,因此id显式传递,后面的includeDisabledUsers是有默认值(false)的,不传也没问题,因此放在一个对象中作为配置项。 这样的好处是你不会少传了什么导致API不能调用,又保留了可扩展性,需要额外的配置项可以在对象里加 |