android开发中-使用Dialog managed dialog

 

managed dialog是指一个生存周期由activity管理的dialog,上面两个例子我们创建的dialog都是生存周期是自己管理的。这样做的好处是代码比较简单明了,需要时就创建,完成后就自动销毁,不好的地方是因为每次调用都需要创建dialog对象,内存开销比较大。而managed dialog则是创建一次而能被多次使用,所以它的核心概念是复用dialog。(这有点像是jdbc的连接池)

那在Activity里如何创建一个managed dialog呢?其实managed dialog跟一般的dialog对象是一样的,只是我们利用连接池的概念用编程的方法来让一般的dialog变成可复用的而已,具体要如何让一个dialog变成可复用的分为下面几个步骤:

1.   在Activity中你可以创建多个dialog对象,首先你需要为每个需要变成managed dialog的dialog赋一个id值(编号),假设我们为一个dialog设置编号是:x。

2.  当需要显示dialog时,告诉Activity需要显示编号是x的dialog (调用: Activity.showDialog(x) )

3.  系统调用onPrepareDialog方法通知即将显示编号是x的dialog,然后检查当前Activity里是否已经有存在一个编号是x的dialog,如果存在则调用dialog的show方法直接显示dialog(跳过创建步骤达到复用dialog的效果)。

4. 如果需要创建的编号为x的dialog不存在则调用onCreateDialog(x)方法告诉系统需要创建编号是x的dialog

5.  这边你需要重写Activity的onCreateDialog回调方法,根据它的参数(参数是编号x)创建对应的Dialog对象,然后返回Dialog,让系统将其放进dialog池。

6. 系统将编号是x的 已经创建完成的dialog显示出来。

7. 当用户点击dialog中的按钮执行回调函数。

 

下面我们演示下如何创建一个managed dialog。首先创建一个Activity在里面添加一个按钮,点击按钮就显示Dialog:

res/layout/dialog2.xml:

 
将上面创建的布局xml文件设置到Activity中:
ManagedDialogActivity.java:
 
为managed dialog定义一个编号id:
 
定义Activity中的按钮事件,当用户点击按钮时显示编号是DIALOG1的dialog:
 
这时候会调用onPrepareDialog方法做一些准备工作,这边你可以动态修改已创建完的managed dialog的属性,如果发现dialog不存在则系统会调用onCreateDialog方法创建dialog对象。所以我们要重写onCreateDialog方法,将创建dialog的代码放在这里:
 
至此需要的工作都完成了,我们来看看效果:
综上我们可以发现创建一个managed dialog和创建一般的dialog差不多,只是由于Dialog需要被管理所以要为每个Dialog附上一个id编号值,然后根据编号值创建、显示和隐藏对话框。总的来说代码多了对编号的控制稍微复杂些,但是当有多个dialog的情况下这样做就能很大的节省内存空间。

 

### 解决 PrimeFaces 中对话框保存时确认框导致 Bean 方法未触发的问题 在 PrimeFaces 的 `<p:dialog>` 和 `<p:confirmDialog>` 组件中,如果点击保存按钮后弹出确认框,并且后台 Bean 的 `save` 方法未被调用,可能是由于以下原因导致的。以下是详细的分析和解决方案: #### 1. 确保组件正确嵌套 PrimeFaces 的 `<p:commandButton>` 和 `<p:confirmDialog>` 必须位于同一个 `<h:form>` 标签内[^2]。如果组件不在同一个表单中,AJAX 提交可能会失败,从而导致 `actionListener` 或 `action` 方法未被触发。 ```xml <h:form id="formId"> <p:commandButton value="Save" type="button" onclick="PF('confirmation').show()" /> <p:confirmDialog widgetVar="confirmation" message="Are you sure?" header="Confirmation"> <p:commandButton value="Yes" action="#{bean.save}" update="formId" oncomplete="PF('confirmation').hide()" /> <p:commandButton value="No" onclick="PF('confirmation').hide()" type="button" /> </p:confirmDialog> </h:form> ``` #### 2. 检查 Managed Bean 的作用域 Managed Bean 的作用域可能会影响 `action` 方法的触发。建议使用 `@ViewScoped`,因为它在视图生命周期内保持状态,避免了 `@RequestScoped` 导致的状态丢失问题[^3]。 ```java import javax.faces.bean.ManagedBean; import javax.faces.bean.ViewScoped; @ManagedBean @ViewScoped public class Bean { public void save() { // 保存逻辑 } } ``` #### 3. 验证 AJAX 配置 默认情况下,`<p:commandButton>` 使用 AJAX 提交。如果需要更新页面的部分区域,确保 `update` 属性正确指向需要刷新的组件 ID。此外,可以通过设置 `process="@this"` 来限制提交的数据范围[^2]。 ```xml <p:commandButton value="Yes" action="#{bean.save}" process="@this" update="growl" oncomplete="PF('confirmation').hide()" /> ``` #### 4. 检查 JavaScript 错误 如果页面上存在 JavaScript 错误,可能会阻止 `<p:commandButton>` 的正常行为。可以通过浏览器开发者工具检查控制台是否有错误信息,并修复相关问题[^1]。 #### 5. 确保 `oncomplete` 正确执行 `oncomplete` 属性用于在服务器端处理完成后执行客户端脚本。如果 `oncomplete` 中的脚本未正确执行,可能导致对话框未关闭或页面未刷新。确保 `oncomplete` 的脚本语法正确[^1]。 ```xml <p:commandButton value="Yes" action="#{bean.save}" update="formId" oncomplete="PF('confirmation').hide()" /> ``` #### 6. 避免表单嵌套 在使用 PrimeFaces 时,应避免 `<h:form>` 嵌套使用。嵌套表单可能会导致不可预测的行为,例如附件上传失败或 AJAX 提交异常[^3]。 --- ### 示例代码 以下是一个完整的示例,展示如何正确配置 `<p:confirmDialog>` 和 `<p:commandButton>`: ```xml <h:form id="formId"> <p:commandButton value="Save" type="button" onclick="PF('confirmation').show()" /> <p:confirmDialog widgetVar="confirmation" message="Are you sure?" header="Confirmation"> <p:commandButton value="Yes" action="#{bean.save}" update="formId" oncomplete="PF('confirmation').hide()" /> <p:commandButton value="No" onclick="PF('confirmation').hide()" type="button" /> </p:confirmDialog> </h:form> ``` ```java import javax.faces.bean.ManagedBean; import javax.faces.bean.ViewScoped; @ManagedBean @ViewScoped public class Bean { public void save() { // 保存逻辑 } } ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值