窗体上的自定义控件弹出另一个窗体,该怎么传回值啊?

student2000 2013-06-22 09:39:55

在窗体form1上有个自定义控件2,它有个按钮,弹出窗体form2.
在form2里,在文本框中输入文字后,点击按钮,关闭form2,想把文字传回给自定义控件2中的文本框里,该怎么写呢?

在自定义控件的按钮中
private void button1_Click(object sender, EventArgs e)
{
Form form2 = new Form2();
form2.ShowDialog();
// this.textBox1.Text = form2.strA;
这么写会出错
}

在form2中
public string strA;
private void button1_Click(object sender, EventArgs e)
{
strA= this.textBox1.Text ;
this.Close();
}

我知道定义一个 public static stringC 可以来传递值,但我想知道如果不用这种方法,还有别的方法来实现吗?
...全文
282 25 打赏 收藏 转发到动态 举报
写回复
用AI写文章
25 条回复
切换为时间正序
请发表友善的回复…
发表回复
xcliang2004 2013-06-24
  • 打赏
  • 举报
回复
刚才没写完按错了。
private void button1_Click(object sender, EventArgs e)
        {
            Form form2 = new Form2();
            form2.OnFormClose+=(string strA){
               this.textBox1.Text  
            }
            form2.ShowDialog();
             这么写会出错
        }
在form2中
         public delegate void CallFormClose(string strA);
        public event CallFormClose OnFormClose;
        private void button1_Click(object sender, EventArgs e)
        {
           if(OnFormClose==null);
           {
               OnFormClose(strA);
           }
           this.Close();
        }
xcliang2004 2013-06-24
  • 打赏
  • 举报
回复
private void button1_Click(object sender, EventArgs e) { Form form2 = new Form2(); form2.ShowDialog(); // this.textBox1.Text = form2.strA; 这么写会出错 } 在form2中 public delegate void CallFormClose(string strA); public event CallFormClose OnFormClose; private void button1_Click(object sender, EventArgs e) { if(OnFormClose==null); this.Close(); }
student2000 2013-06-24
  • 打赏
  • 举报
回复
嗯,我用xiaomingelv说的构造函数实现了。 不过还是想知道sp1234说的 “如果你不知道“事件驱动”的概念,那么你的基本的程序设计知识缺少了一半。因为至少有一半的程序代码,是在实践处理方法中提交的。包括你这个 button1_click 方法也是这样。而你会在button1_click写代码,却不知道要在Closed事件处理过程中写代码,这就好像“骑驴找驴”,说明你还是只会抄袭、还没有接受基本的“事件驱动设计”概念。” 这段话在这个问题中有是什么含义?
u011182701 2013-06-23
  • 打赏
  • 举报
回复
构造函数就可以了。
student2000 2013-06-22
  • 打赏
  • 举报
回复
请xiaomingelv帮看看,这样写为何不对: 我在form1上增加了一个textBox1,将modifiers属性改为public 然后Form2的代码是 public partial class Form2 : Form { public Form2() { InitializeComponent(); } Form1 b; public Form2(Form1 a) { b = a; } public string strA; private void button1_Click(object sender, EventArgs e) { strA= this.textBox1.Text ; b.textBox1.Text = strA;//提示未将对象引用设置到对象的实例 this.Close(); }
小敏哥 2013-06-22
  • 打赏
  • 举报
回复
引用 7 楼 student2000 的回复:
[quote=引用 1 楼 xiaomingelv 的回复:] 如果我没理解错的话可以把自定义控件2本身作为form2的构造函数的参数,然后点击弹出form2的按钮时调用自定义的构造函数,这样就能在form2中调用你自定义的控件里面的控件了
请问您能能给具体代码吗?我对C#不熟。[/quote] 老大。。。这样还不够清楚啊,你就是个给form2增加一个有参构造函数,然后再在form2中添加一个变量 form1 b比如说form2(form1 a){ a就是form2 的父窗口,赋值 b=a;} ,之后再button1的点击事件中直接调用b,b.textBox1.Text="需要的字符串",这不就结了?????虽然不是最好的办法,但应该是最容易理解的了。。。
student2000 2013-06-22
  • 打赏
  • 举报
回复
引用 2 楼 sp1234 的回复:
private void button1_Click(object sender, EventArgs e) { Form form2 = new Form2(); form2.ShowDialog(); form2.Closed += 这里按两次TAB键 }
只有form2.Close啊没有form2.Closed啊, 您是要写 form2.FormClosed += new FormClosedEventHandler(form2_FormClosed); 吗?然后又怎么写才能得到那个form2上的文本值呢? 不好意思,确实基础差。
u010546900 2013-06-22
  • 打赏
  • 举报
回复
自己定义一个UIContext类,作为类之间的数据传输
student2000 2013-06-22
  • 打赏
  • 举报
回复
引用 1 楼 xiaomingelv 的回复:
如果我没理解错的话可以把自定义控件2本身作为form2的构造函数的参数,然后点击弹出form2的按钮时调用自定义的构造函数,这样就能在form2中调用你自定义的控件里面的控件了
请问您能能给具体代码吗?我对C#不熟。
student2000 2013-06-22
  • 打赏
  • 举报
回复
引用 4 楼 sp1234 的回复:
如果你不知道“事件驱动”的概念,那么你的基本的程序设计知识缺少了一半。因为至少有一半的程序代码,是在实践处理方法中提交的。包括你这个 button1_click 方法也是这样。而你会在button1_click写代码,却不知道要在Closed事件处理过程中写代码,这就好像“骑驴找驴”,说明你还是只会抄袭、还没有接受基本的“事件驱动设计”概念。
唉,我确实是个C#新手。
  • 打赏
  • 举报
回复
引用 3 楼 ruhuaxiao 的回复:
可以有多重方法啊, 比如 你建立一个 委托 然后用事件返回 ,但是我觉得这个太麻烦了。下面有代码你看看
你的代码中只有委托,没有事件。
  • 打赏
  • 举报
回复
如果你不知道“事件驱动”的概念,那么你的基本的程序设计知识缺少了一半。因为至少有一半的程序代码,是在实践处理方法中提交的。包括你这个 button1_click 方法也是这样。而你会在button1_click写代码,却不知道要在Closed事件处理过程中写代码,这就好像“骑驴找驴”,说明你还是只会抄袭、还没有接受基本的“事件驱动设计”概念。
ruhuaxiao 2013-06-22
  • 打赏
  • 举报
回复
可以有多重方法啊, 比如 你建立一个 委托 然后用事件返回 ,但是我觉得这个太麻烦了。下面有代码你看看
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;

namespace 一个窗体对另一个窗体的数据进行修改
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        private Form2 f2 = new Form2();
        
        private void button1_Click(object sender, EventArgs e)
        {
            f2.xiugai=new Form2.my(f2_Event);
            f2.Show();
            
        }
        private void f2_Event(string str)
        {
            label1.Text = str;
        }
    }
}
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;

namespace 一个窗体对另一个窗体的数据进行修改
{
    public partial class Form2 : Form
    {
        public Form2()
        {
            InitializeComponent();
        }
        public delegate void my(String str);//第二个窗体中设置委托
        public my xiugai; //用委托定义一个 类似方法
        //public event my xiugai ;   //一样的效果
        private void button1_Click(object sender, EventArgs e)
        {
            xiugai(textBox1.Text.ToString());
        }

        private void Form2_Load(object sender, EventArgs e)
        {

        }
    }
}
这是常用的 另外一个方法 就是在类 之下 构造函数之前定义一个 internal的 静态字段。 当然这个类也需要改成internal的 然后在该类中把 你想传递的值赋给这个字段, 在另外一个类中,就可以 用类名.字段名的方法来获取这个值了 ,(string 也可以穿,连控件估计都能传,但是没有试)
  • 打赏
  • 举报
回复
private void button1_Click(object sender, EventArgs e) { Form form2 = new Form2(); form2.ShowDialog(); form2.Closed += 这里按两次TAB键 }
小敏哥 2013-06-22
  • 打赏
  • 举报
回复
如果我没理解错的话可以把自定义控件2本身作为form2的构造函数的参数,然后点击弹出form2的按钮时调用自定义的构造函数,这样就能在form2中调用你自定义的控件里面的控件了
student2000 2013-06-22
  • 打赏
  • 举报
回复
引用 17 楼 u011130289 的回复:
直接建个类,把你要传的值放进去,在新窗口读取就可以了,不用那么麻烦了
我一开始也是这么做的,在一个类里放一个public static string,但我是新手,并且新到公司,老员工说这么不好,我不知是哪不好,也可能是不符合现有程序的风格。所以我想找别的办法。
tcmakebest 2013-06-22
  • 打赏
  • 举报
回复
这种情况大家都会遇到的,介绍一下我的解决方式: 在子窗体中放如下一个函数,然后在父窗体调用此函数, 在这个函数内部弹出窗体 如果返回不是null,则表示成功地输入了 public static string ShowFormInput(string str) { Formxx f=new Formxx(); f.str=str; if(f.ShowDialog()==DialogResult.OK){ return f.str; } return null; }
Regan-lin 2013-06-22
  • 打赏
  • 举报
回复
直接建个类,把你要传的值放进去,在新窗口读取就可以了,不用那么麻烦了
Regan-lin 2013-06-22
  • 打赏
  • 举报
回复
引用 5 楼 sp1234 的回复:
[quote=引用 3 楼 ruhuaxiao 的回复:] 可以有多重方法啊, 比如 你建立一个 委托 然后用事件返回 ,但是我觉得这个太麻烦了。下面有代码你看看
你的代码中只有委托,没有事件。[/quote] 我连事件的声明都没看到···
student2000 2013-06-22
  • 打赏
  • 举报
回复
引用 4 楼 sp1234 的回复:
如果你不知道“事件驱动”的概念,那么你的基本的程序设计知识缺少了一半。因为至少有一半的程序代码,是在实践处理方法中提交的。包括你这个 button1_click 方法也是这样。而你会在button1_click写代码,却不知道要在Closed事件处理过程中写代码,这就好像“骑驴找驴”,说明你还是只会抄袭、还没有接受基本的“事件驱动设计”概念。
很想知道您怎么在close事件中去实现把form2中的值传回给那个自定义控件的目的啊,确实我一直写程序基本上都是复制粘贴。 form2.Closed += 这里按两次TAB键 这不行啊。
加载更多回复(3)
UIDesigner(腾讯公司出品) 在软件设计阶段,交互设计师或者产品经理等常常需要使用一些工具(比如Visio、Axure RP、Flash或者OmniGraffle等)制作出静态稿或者原型来表达设计思想。这些工具是各有各的优势,当然也各有各的缺点啦。那么腾讯CDC是如何设计软件原型的呢?这里向大家介绍我们正在研发的原型设计利器UIDesigner。   首先,先让我们来体验一下UIDesigner制作出来的原型效果。这个原型是一个设置窗体,主要由按钮、复选框、分组框和文本框等控件构成,其中一些按钮还具有响应的动作(如打开另一个界面,关闭窗体等)。如图一所示,这是使用Firework制作出来的交互图。 图一、使用Firework制作出来的设计稿   这种交互图的特点是简单明了,能够表示出各种控件的基本属性(如文本、位置和选中状态等),但它只是一个静态的图片,不能真实表现出每个控件的响应动作,如仅看这张图,是不清楚点击代理服务器设置分组框上的“设置…”按钮会有什么响应的。   那再看看你若使用UIDesigner制作出来的效果:最终输出的是一个EXE可执行文件(见图二左上角),双击运行后就会出现一个与最终实现效果完全一致的窗体(见图二右)。另外,它还是一个具有响应动作的真实原型,例如你若点击了“设置…”按钮,那就会弹出一个新的窗体(见图三)。 图二、使用UIDesinger制作出来的原型 图三、点击“设置…”按钮后弹出的另一窗体   实际上,这个新弹出窗体都是一个独立的原型,也是由UIDesigner制作出来的。由于它里面的控件同样可以设置下一步的响应动作,所以从总体上来看,众多原型就像一个树状结构,而其中的父节点就是图二中的设置窗体了。这种结构具有一个很大的好处:无论你完成了多个界面的原型,只需要它们之间有链接关系,最后输出的只是一个EXE可执行文件。这样,你可以很方便地与其它人员表达自己的设计思路,让沟通变得更加快捷。   接下来,我们看看这个原型是如何制作出来的。   第一步:建立空白窗体,调整它的大小、风格、标题和Icon 图四、使用UIDesigner制作原型—建立窗体   第二步:从工具箱中拖曳控件到窗体上,修改这些控件的属性(如Text等) 图五、使用UIDesigner制作原型—加入控件   由于UIDesigner具有自动对齐的功能,所以在拖动控件到窗体时就可以完成排版工作,不需要再逐个像素去调整。另外,不单单在加入控件到窗体时,在改变已存在于窗体内的控件的位置或者大小时,自动对齐功能一样会生效。这样,设计者在调整控件大小或者位置时(包括控件与控件,控件与窗体边缘等的距离等情况),工作变得很简单。 图六、使用UIDesigner制作原型—自动对齐功能   第三步:几分钟后,所有的控件都放到窗体并设置好属性了,如下图。 图七、使用UIDesigner制作原型—整体界面效果   此时,设计者就可以使用软件的导出图片或者导出原型功能分享你的设计成果了。当然,现在这种效果还只是一个没有响应动作效果的原型。接下来,我们再给“设置…”按钮加入响应动作。首先,选中“设置…”按钮,然后点击工具栏的“响应”按钮,你将会看到如图八的响应设置窗口。此时,你可以选择打开窗体、打开网页、弹出对话框、修改属性和关闭本身窗体等五种效果,这里我们选择“打开窗体”,然后在弹出的对话框里指向弹出窗体的文件。最后,点击“完成”按钮即可。 图八、使用UIDesigner制作原型—设置控件的响应动作   到此为止,你就完成了一个与最终实现效果完全一致的高保真原型了。产品经理和开发人员等若想了解你的设计思想就不需要看着长长几页的说明文档了,而只需要运行你输出的原型文件,就可以对你的设计思路一目了然。   UIDesigner除了能让使用者能够快速地搭建起软件界面的高保真原型外,还提供了项目管理,让使用者能够方便地管理工程文件;提供了图片库和模板库功能,让使用者可以方便地重用以前的设计资源;提供了32个Windows客户端软件常用控件,满足使用者的设计需求;提供了多个属性设置入口,分别实现最常用属性设置、一般属性设置和高级属性设置功能。当然,UIDesigner不是专用来设计QQ的,其它的Windows客户端产品都在它的工作范围之内。总的来说呢,使用UIDesigner来制作原型是很高效的,而制作出来的原型也能够实现设计师、产品经理和程序开发工程师三者间的快速沟通,减少不必要的工作内耗。 ------------------------------------------------------------------ GUI_Design_Studio_3.5.94.0 在2008年,这款软件的作者从1,322位付费用户那获得了162,302美元的收入(其中仅12月份就有39,000美元),这令人鼓舞地证明了只要是提供真正价的服务和软件,就能够创造很好的收入,即使在经济萧条的寒冬里。 GUI Design Studio是一款图形用户界面设计工具,您能用它在不需要编写任何代码或脚本的情况下快速地创建演示原型。使用标准元素绘制个人化的屏幕、窗口以及控件;将它们整合以展示操作工作流然后运行模拟程序测试您的设计。 当您需要绘制一款应用程序的外观或显示怎样将程序的各个部分连接起来时,您就可以使用GUI Design Studio来实现,如: 将产品创意文档化 制作项目提案 需求记录 创建屏幕图样 为开发人员制作详细的规格 为现有产品提出加强方案 以及更多其它用途 为用户以及股东甚至您自己制作展示文件以: 验证设计 找出替代项 评估多个使用场景 系统需求 Microsoft Windows Vista/XP/NT/2000 至少15MB的硬盘空间 推荐不少于256MB的内存 工程 将您的工作组织放到工程里。 每个工程都拥有它自己的文件夹结构。 可连接您计算机或网络上任何地方的其它库工程。 可连接到您计算机或网络上任何地方使您能够方便地获取图片以及其它文件。 创建您想要的并独立于所有工程的个人化设计文件。 创建能重复使用的设计库以及工程之间的一致性。 将图片直接从剪贴板中粘贴到工程文件夹的文件中。 屏幕设计程序 可同时打开多个设计文档并能使用分页界面在文档间快速切换。 可使用标准Windows元素创建图形用户界面(GUI)屏幕,包括框架窗口、会话、菜单、工具栏、标签、按钮、复选框、单选按钮、滚动条、滑动调节框、微调框、组合框、树列表、列表框、编辑框以及静态文本等。 通过现有元素或其它自定义控件创建自定义控制组件。 在其它设计中创建将要使用的控件设计。 以常用的文件格式添加图标与图片。 从能够显示您将获得什么的控件面板中进行拖放操作。 属性编辑程序使您能将每个元素进行自定义。 元素的自动生成功能。 您能在任何地方放置任何元素。 Edge snapping能通过“点击”对屏幕元素进行统一记录。 设计网格向您提供了简单的制作具有一致性设计布局的方法。 只需单键点击就能排列元素组。 均衡地隔开元素组。 调整元素大小以适应其它元素或测量一组其它元素。 聚焦缩小以查看细节设计或聚焦放大以浏览设计概况。使用工具栏按键或键盘或鼠标的滑动缩小放大功能聚焦增量。 使用鼠标的滚动以及滚轮功能快速浏览设计的概况。 剪切、复制与粘贴。 使用可选的canvas向导显示可用的屏幕空间。 通过文本框与书签对您的设计进行注释。 为每个设计添加说明。 选择色彩主题以避免实际功能窗口的混淆。 图标 为图标面板提供快速的访问方式。 工程间可共享常用图标。 工程也能拥有它们独享的图标集。 使用将来在实际产品开发中可能用到的标准ICO文件。 包含的Icon Express编辑程序支持16色、256色以及最大尺寸为127 x 127的真彩图标。 如果愿意同样能整合任意其它的图标编辑应用程序。 展示与原型 在可导航元素(如按键与窗口)之间创建连接以显示控制流程。 为图象添加覆盖保护以及添加其它元素以创建可导航的热点。 支持形式化与非模态的窗口并支持显示、隐藏或微调窗口,以及窗口替换以实现切换效果。 锚点使您能对窗口进行准确定位。 能立即在模拟程序中测试或展示您的设计。 添加消息框以描述可能在真实应用程序中出现的功能。 可创建多种场景,如正常条件下的场景与多个出错场景。 选择要激活的场景或让模拟程序为您选择。 更改有效的屏幕分辨率以查看您的设计如何适应不同的屏幕大小。 在没有进行脚本或代码编写的情况下,所有操作都是以图形模式完成。 ------------------------------------------------------------------ Balsamiq_Mockups_1.8.4 1. 首先安装 AdobeAIRInstaller.exe 2. 安装主程序 MockupsForDesktop.air 3. 使用 keygen 进行注册 在Balsamiq Mockups中绘制界面原型,就像在纸张和白板上手工绘画一样方便快速,而且不用担心出错,因为你完全可以进行回复/重做。在Balsamiq Mockups中设计原型比在纸张和白板可有趣多了! 丰富的控件支持 Balsamiq Mockups预先提供了丰富的控件,如浏览器窗口、媒体播放器组件、圆形图表等,让你信手拈来! 丰富的控件 方便的属性设置 当你选择一个控件时,会立刻出现该控件的属性选项,你可以随时编辑修改属性。 属性设定 无限的恢复/重做,不用担心出错,你可以无限制的进行回复和重做。 开放,可移植的数据 Balsamiq Mockups所生成的数据是易于阅读的XML格式数据,你可以进行方便的移植和重用集成。 开放的数据 多种方式的集成应用,你可以将Balsamiq Mockups集成倒Confluence, Jira, XWiki中. 集成应用 Balsamiq Mockups是一款免费的带有手绘风格的原型设计软件,可以帮助你设计桌面应用软件,Web 2.0 站点, RIA富网络应用程序, Web站点和Web应用软件。 功能和亮点: 操作方面:拖拽,控件分组,甚至元素之间的对齐都做得很到位; 预制了六十多个界面元素,从简单的输入框,下拉框,到经常用得到的导航条,日历,表格,到复杂的Tag Cloud,Cover Flow, 地图,WYSWYG的格式工具栏等,有了这些不用从头画起,其实比用白板都快; 界面元素的修改很简单,比如导航条的几个标签页的label,就是用逗号分隔的文字,下拉框的选项就是分行的文字; 使用xml语言来记录和保存界面元素和布局,从而使其能够快速的导入到你所需的任何一个项目中,或其他工具中。 可以将设计导出成PNG格式的图片; 随着使用的熟练,快捷键便派上用场,超过一半的元素均有快捷方式,这更有助于原型的快速构造,几乎几分钟便可实现一个满意的而复杂的原型设计; 跨平台,Balsamiq Mokups是用Flex和Air实现的,所以在Mac OS, Linux和Windows下都能使用; 不仅仅有桌面版本,还有能集成在Confluence,JIRA,和XWiki中的版本,使得异地在线协作更方便有效。 可以用命令行进行导出操作,这样就能让我写个脚本,从svn里checkout某个目录下的所有设计文件后,导出图片,打包后用邮件发到项目经理,工程师甚至客户那; 跨平台,Balsamiq Mokups是用Flex和Air实现的,所以在Mac OS, Linux和Windows下都能使用;不仅仅有桌面版本,还有能集成在Confluence,JIRA,和XWiki中的版本,使得异地在线协作更方便有效;据作者说,现在这款软件的设计就是用它自己来设计的,经典的“吃自己的狗粮”,这也让我对其更有信心,因为它是开发者为开发者写的软件。 还有得一提的是Balsamiq Mokups的在GetSatisfaction上的用户支持和服务,作者Peldi对问题报告,新需求的回应很积极和及时。而且根据这个讨论上看,到月底就会有一个专门用来分享界面控件设计的社区网站了,很期待。 再要说的一点是这款软件是要付费的,79美元(也可以免费,具体如何免费,请看网站上的说明),相对于它能节省下来的时间和提高的效率,是很得的。Peldi说在2008年,这款软件就从1,322位付费用户那获得了162,302美元的收入(其中仅12月份就有39,000美元),这令人鼓舞地证明了只要是提供真正价的服务和软件,就能够创造很好的收入,即使在经济萧条的寒冬里。

110,566

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧