caoxwei2 2016-03-22 04:53 采纳率: 100%
浏览 1517
已采纳

重构自己的代码,减去重复的部分

在实际的项目中,有一个程序包含三个窗体,这三个窗体包含同一个模块(执行Sql插入的模块,由三个textBox和一个执行插入操作的按钮),
sql语句如下:
sqlStr="insert into task(headline,keyword,content) values(' "
+textBox_headline.Text + " ','"
+ textBox_keyword.Text + "','"
+textBox_content.Text + "')";
现在的问题是,三个窗体都出现相同的代码,显然违反了Don't Repeat Yourself的
原则,我的想法是将这部分提取到一个类中,减少重复,但是textBox_headline,
textBox_keyword,text_content不知道如何处理,因为新的类根本就没有textBox,
请问如何解决这个问题?

  • 写回答

2条回答 默认 最新

  • danielinbiti 2016-03-22 05:46
    关注
    TextBox作为参数传入
     sub insertSQL(textBox_headline as TextBox,textBox_keyword as TextBox,textBox_content as TextBox)
       sqlStr="insert into task(headline,keyword,content) values(' " 
    +textBox_headline.Text + " ','" 
    + textBox_keyword.Text + "','"
    +textBox_content.Text + "')";
     end sub
     建议传入的参数是TextBox的值,不建议把控件名称传入到类或者模块里面
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 孟德尔随机化r语言运行问题
  • ¥15 pyinstaller编译的时候出现No module named 'imp'
  • ¥15 怎么把多于硬盘空间放到根目录下
  • ¥15 Matlab问题解答有两个问题
  • ¥50 Oracle Kubernetes服务器集群主节点无法访问,工作节点可以访问
  • ¥15 LCD12864中文显示
  • ¥15 在使用CH341SER.EXE时不小心把所有驱动文件删除了怎么解决
  • ¥15 gsoap生成onvif框架
  • ¥15 有关sql server business intellige安装,包括SSDT、SSMS。
  • ¥15 stm32的can接口不能收发数据