Showmodal与Show的区别

Showmodal是个函数,Show是个过程

1.Showmodal:

概念:

    当你调用一个窗口用SHOWMODAL时,当这个窗口显示出来后,程序不会继续自己执行,而是根据你对这个窗口的操作来执行,只有关闭了这个窗口后才会执行。

属性:

FormStyle改为fsNormal,visible改为false

2.Show:

概念:

     SHOW不同,当窗口显示后,代码一样往下执行的,即程序会继续执行。

属性:

FormStyle改为fsMDIChild,visible改为True

 

 

 

消息窗体ShowModal()显示时,主窗体是能够处理下一条消息的。使用ShowModal()显示时,其它的窗体
只是不接受用户的操作而已。

---------------------------------------------------------------

综上所述,另外,Form ShowModal() 时相当于执行了一个 Call ,也就是 ShowModal() 以下的代码在 ShowModal() 出的窗体被关闭前是不会被执行的,但并不影响父窗体的消息循环,这也正是与单一 Show() 的区别!

 

 

 

ShowModal 出来的对话框必须关掉才能处理其他窗体.也就是当前焦点不能转移到其他的窗体上,除非关掉.
Show 出来的对话框则可以将当前焦点转移到其他界面上.

 

 

Create(**)这个是要看具体的哪个函数了,一般来说Delphi自带的那几个控件,它是来用指定它的属主的,如果置为nil的时候,这个控件是自操作的,也就是说释放什么的,你要自己管.如果你设了一个属主后,这个释放你就不用管了,它的属主被释放的时候,它自己也同时会被释放.



Delphi 里 Show出来的一般是子窗体,对话框叫非模式对话框,ShowModal 出来的是主窗体,叫模式对话框.

两种窗体的区别主要是模态和非模态的.无论在哪种开发什么,应该都是这样的,甚至连网页打开的窗体也是一样的.

 

 

 

ShowModal与Show的区别

在用delphi开发时,碰到这样的问题:fomr2.ShowModal出现cannot  make  a  visible  window  modal错误,但fomr2.Show则正常,为什么?

因为ShowModal与Show是不同的。

 fomr2.ShowModal时,要求Form2.Visiable=False,假使你设置为Visiable=True就会产生错误:  

ShowModal函数定义:

 function  TCustomForm.ShowModal:  Integer;  

var  

 WindowList:  Pointer;  

     SaveFocusCount:  Integer;  

     SaveCursor:  TCursor;  

     SaveCount:  Integer;  

     ActiveWindow:  HWnd;  

 begin  

     CancelDrag;  

     if  Visible      //Form.visible=True.  

           or  not  Enabled  or  (fsModal  in  FFormState)  or  

         (FormStyle  =  fsMDIChild)  then  

         raise  EInvalidOperation.Create(SCannotShowModal);  //产生一个raise,出错误。  

     其中 SCannotShowModal  =  'Cannot  make  a  visible  window  modal';      

 ...  

 end  

   

 fomr2.Show时,要求Form2.Visiable=True或False都不会错。  

 

Show函数定义:  

 procedure  TCustomForm.Show;

 begin  

     Visible  :=  True;  

     BringToFront; 

 end;

### 如何在uni-app中自定义`showModal`的使用方式和样式 #### 使用全局组件实现自定义`showModal` 为了使`showModal`具有更丰富的功能并能全局应用,可以通过创建一个名为`G_show_modal`的全局组件来达成这一目的[^2]。此方法允许开发者不仅能够调整弹窗的内容布局,还能覆盖原有的标题栏以及底部导航栏。 ```javascript // main.js 中引入并注册该全局组件 import G_show_modal from '@/components/G_show_modal/g_show_modal.js' Vue.use(G_show_modal); ``` 上述操作使得在整个项目范围内都可以方便地调用这个增强版的消息提示框而无需重复导入。 #### 定制化消息对话框外观设计 对于那些追求更高灵活性的应用场景而言,在不改变原有API接口的前提下对默认行为做出改进是非常有价值的。具体来说就是保持标准`uni.showModal()`相同的参数配置逻辑的同时增加额外选项用于控制视觉效果和其他交互特性[^1]。 例如: - 支持传入HTML片段作为内容区域的一部分; - 提供多种预设的主题配色方案让用户自行挑选; - 实现响应式布局适应不同屏幕尺寸下的最佳呈现; 这些改动都旨在提升用户体验质量而不影响到现有代码结构的一致性和简洁度。 #### 动态加载所需UI元素 考虑到实际开发过程中可能会涉及到频繁变更的需求,预先准备好所有可能需要用到的各种类型的控件不失为一种明智的选择。借助于条件渲染指令(如v-if)或是CSS类名切换机制,则可以根据实际情况灵活展现特定部分的信息[^3]。 ```html <!-- 假定这是g-show-modal.vue 文件内的部分内容 --> <template> <!-- ...省略其他无关标记... --> <div v-if="isCustomContent"> <!-- 这里放置动态生成或者由外部传递进来的复杂DOM结构 --> </div> </template> <script> export default { props: ['customContent'], computed:{ isCustomContent(){ return !!this.customContent; } }, } </script> ``` 通过这种方式既保证了基础框架稳定可靠又赋予了足够的自由空间去满足个性化定制的要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值