在实际的项目中,有一个程序包含三个窗体,这三个窗体包含同一个模块(执行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,
请问如何解决这个问题?
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的值,不建议把控件名称传入到类或者模块里面
你就用三个全局的string代替其中的textbox.text呗,给全局变量赋值就行了