参数传递的几种用法。

参数传递的几种用法。

一次需要在几个窗口之间传递参数,最开始想到的是定义一个全局变量。

可以做了以后发现并不太理想。

最后向别人学习了参数传递,解决了很多问题,感觉上也不容易出错。

现在写出来与大家分享,也为自己保留,以便察看。
-----------------------------------------------------------
先来解释一下参数传递的函数意义:
message.stringparm  (传的是字符)
message.DoubleParm   (传的是数值)
message.PowerObjectParm (传的是可以是窗口、对象、结构等等)
例如:(以数值传递为例)
在w_old窗口的相关事件中写入如下代码,表示发送要传递参数:
long ll_old
ll_old = 你要传递的数值
openwithparm(w_new(//新窗口),ll_old)
------------
在w_new窗口(新窗口)的相关事件中写如下代码表示接受参数:
long ll_new
ll_new = Message.DoubleParm /*这样就接收到了你要的参数了。*/
-----------------------------------------------------------

上面只是一个参数的传递,
对于多参数的传递,说是有3种方法:
      1.用字符传组传递,到目的地进行分割
      2.传递结构对象
      3.用对象做载体传递 
我现在掌握的也就前两种,最后一种我不太理解。以后会了再补充。

现在先来说:1.用字符传组传递,到目的地进行分割
意思也就是说,把多个参数组合成一个进行传递,
组合的时候需要加入分割符---自己定义的。接收参数后再将其分割成多个。
*在w_old窗口的相关事件中写入如下代码:
/*例如组合好的自符串为pass_old="123|4567"  ---注意组合前123和4567
可能都是long型的,不要紧,转换类型就行*/
string pass_old
pass_old =string(ll_pre) + "|" + string(ll_tra)
// ll_pre = 123,ll_tra = 4567
openwithparm(w_new(//新窗口),pass_old)
----------
*在w_new窗口(新窗口)的相关事件中写如下代码:
integer li_fen /*定义用来记录分割符的位置*/
long ll_newpre,ll_newtra /*用来分别存放两部分*/
string pass_new
pass_new = message.stringparm

li_fen=Pos(pass_new,"|") /*确定并记录分割符的位置*/

ll_newpre=long(left(pass_new,li_fen - 1))

ll_newtra=long(right(pass_new,len(pass_new) - li_fen))

/* 上面就是第一种方法-----用字符传组传递,到目的地进行分割*/
--------------------------------------
在来说说:2.传递结构对象
在库文件中 创建一个structure对象,注意是创建,因为它就象一个窗口一样
是个对象,不是用与句定义的。structure s_info
  变量名      变量类型
  ID         long
  Name        Char
    Sex         Char
/* 先以此为例。 */
**在w_old窗口的相关事件中写入如下代码:
s_info lstr_pre
lstr_pre.id = 1 /* 赋ID的值
lstr_pre.name = "zhdleo"  /* 赋name的值
lstr_pre.name = "male"  /* 赋sex的值
openwithparm(w_new(//新窗口),lstr_pre)
**在w_new窗口(新窗口)的相关事件中写如下代码:
s_info lstr_tra
long tra_id
string tra_name
string tra_sex /* 定义要接收的变量

lstr_tra = message.PowerObjectParm /* 接收参数
tra_id = lstr_tra.id 
tra_id = lstr_tra.name
tra_id = lstr_tra.sex /* 赋值

/* 上面就是第二种方法------传递结构对象
-------------------------------------------
我个人觉得第二种方法还是非常优的,不但结构清楚,而且定义了结构体也
可以看见,容易理解。

至于第三种,还有待我慢慢研究。

如果谁还有好的方法,或是比较清楚第三种的,或是还有更好的方法的,
E-mail:zhdleo@163.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis获取参数的几种方式有: 1. 使用@Param注解:在Mapper接口的方法参数列表中使用@Param注解,可以为参数取一个名字,方便在SQL语句中引用。 例如: ``` @Select("SELECT * FROM user WHERE id = #{id}") User getUserById(@Param("id") int userId); ``` 2. 使用Map类型参数:在Mapper接口的方法参数列表中使用Map类型参数,可以将所有参数封装到Map中,通过键值对的方式传递参数。 例如: ``` @Select("SELECT * FROM user WHERE id = #{id} AND name = #{name}") User getUserByIdAndName(Map<String, Object> paramMap); ``` 3. 使用POJO类型参数:在Mapper接口的方法参数列表中使用自定义的POJO类型参数,可以将参数封装到一个对象中,通过对象的属性名来引用参数。 例如: ``` @Insert("INSERT INTO user (id, name, age) VALUES (#{id}, #{name}, #{age})") int addUser(User user); ``` 4. 使用数组类型参数:在Mapper接口的方法参数列表中使用数组类型参数,可以将多个参数封装到一个数组中,通过数组下标的方式来引用参数。 例如: ``` @Select("SELECT * FROM user WHERE id IN (#{ids})") List<User> getUsersByIds(@Param("ids") int[] ids); ``` 5. 使用List类型参数:在Mapper接口的方法参数列表中使用List类型参数,可以将多个参数封装到一个List中,通过List中元素的位置来引用参数。 例如: ``` @Select("SELECT * FROM user WHERE id IN (#{ids})") List<User> getUsersByIds(List<Integer> ids); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值