- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
我在所有 View 中都以这种方式显示对话框:
<f:view locale="#{loginBB.localeCode}">
<ui:insert name="dialogs" />
<p:messages autoUpdate="true" closable="true" redisplay="false" />
<ui:insert name="content" />
</f:view>
但它们显示在页面底部
我已使用 CSS 在所有对话框中进行了此更改:
/* Put the dialogs on the top of the screen. It only works on firefox */
.ui-dialog {
position: absolute;
}
/* Disable scroll on the loading dialog */
.disable-scroll .ui-dialog-content {
overflow: hidden;
width: auto;
}
他们没有在屏幕顶部显示什么?
编辑:我删除了 CSS 样式,但对话框仍然出现在 iPad 页面的底部。明天我将在 Mac OS X 的 safari 中测试这个
这是我的 styles.css 文件:
td.right {
text-align: right;
}
td.center {
text-align: center;
}
table td,table tr {
vertical-align: top;
}
.ui-datatable .ui-datatable-data tr,.ui-datatable .ui-datatable-data-empty tr,.ui-datatable .ui-datatable-data td,.ui-datatable .ui-datatable-data-empty td
{
border-color: #C1DFFA;
}
.odd-row {
background: #ECF5FE;
}
.ui-panelgrid tr,.ui-panelgrid td {
border: none;
}
.ui-panelgrid td {
padding: 2px;
}
.panelgrid-center {
margin: 0 auto !important;
}
.ui-inputfield.uppercased {
text-transform: uppercase;
}
.ui-inputfield {
text-transform: uppercase;
}
.ui-inputfield.no-uppercased {
text-transform: none;
}
.ui-selectonemenu {
width: 144px !important;
}
.ui-selectonemenu-label {
font-size: 95%;
width: 100% !important;
}
.ui-selectonemenu-panel .ui-selectonemenu-list-item {
font-size: 95%;
overflow-x: hidden;
}
.ui-inputtext {
width: 137px !important;
}
.ui-widget {
font-size: 70%;
}
.ui-panel {
float: left;
}
.ui-outputlabel-rfi {
color: red;
}
.ui-outputlabel {
font-weight: bold;
}
.ui-menubar {
background: #C1DFFA;
}
.ui-panel .ui-panel-content {
padding: 0;
}
.ui-datatable thead th,.ui-datatable tbody td,.ui-datatable tfoot td {
padding: 2px;
}
.justify-text {
text-align: justify !important;
}
.negative-number {
color: red;
}
.small-icon {
height: 15px;
width: 15px;
}
.small-inputtext {
width: 80px !important;
}
.full-width {
width: 100%;
}
我的模板文件:
<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:o="http://omnifaces.org/ui" xmlns:p="http://primefaces.org/ui"
xmlns:ui="http://java.sun.com/jsf/facelets">
<f:view contentType="text/html">
<h:head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<link href="#{resource['images:favicon.ico']}" rel="shortcut icon"
type="image/x-icon" />
<script type="text/javascript">
$(document).ready(
function() {
$("div[role='tabpanel']").attr("aria-hidden", "false").attr(
"style", "display: block");
$("h3[role='tab']").removeClass("ui-corner-all").addClass(
"ui-corner-top ui-state-active").find("span").attr(
"class", "ui-icon ui-icon-triangle-1-s");
});
</script>
</h:head>
<h:body>
<o:importConstants type=" ... Constants 1 ... " />
<o:importConstants type=" ... Constants 2 ... " />
<h:outputStylesheet library="css" name="styles.css" />
...
<p:panelGrid>
<p:row>
<p:column>
... Here is located the application menu ...
</p:column>
<p:column>
<f:view locale="#{loginBB.localeCode}">
<ui:insert name="dialogs" />
<p:messages autoUpdate="true" closable="true" redisplay="false" />
<ui:insert name="bodyContent" />
</f:view>
</p:column>
</p:row>
</p:panelGrid>
</h:body>
</f:view>
</html>
View 示例:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE composition PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:o="http://omnifaces.org/ui"
xmlns:of="http://omnifaces.org/functions"
xmlns:p="http://primefaces.org/ui"
xmlns:pe="http://primefaces.org/ui/extensions"
xmlns:ui="http://java.sun.com/jsf/facelets"
template="/WEB-INF/templates/main_template.xhtml">
<ui:define name="bodyContent">
... Body components ...
</ui:define>
<ui:define name="dialogs">
<p:dialog closeOnEscape="true"
header="Find products" id="products"
modal="true" position="top" widgetVar="productsWV">
<h:form id="productsForm">
<p:focus for="productName" />
<pe:keyFilter for="code" mask="pint" />
<pe:keyFilter for="productName" mask="alpha" />
<f:view locale="#{loginBB.localeCode}">
<p:messages closable="true" />
</f:view>
<p:panelGrid columns="1">
... Dialog components ...
</p:panelGrid>
</h:form>
</p:dialog>
</ui:define>
</ui:composition>
Chrome 在查看内容之前保留对话框的空间:
上次编辑(发现错误)
添加 styles.css
文件后,我得到了以下代码:
<h:form>
<p:ajaxStatus onerror="loadingDLG.hide(); ajaxErrorDLG.show()"
onstart="loadingDialog.show()" onsuccess="loadingDLG.hide()">
</p:ajaxStatus>
<p:dialog closable="false" draggable="false" modal="true"
resizable="false" showHeader="false" styleClass="disable-scroll"
widgetVar="loadingDialog">
<p:graphicImage value="#{resource['images:loading.gif']}" />
</p:dialog>
</h:form>
如果我将其从模板中删除, View 和对话框将完美显示。我不知道如何把它放在模板中,因为我需要它
最佳答案
您根据 my answer 以这种方式实现了对话框组合在 your previous question关于防止 <p:messages>
在后台重新显示对话框的消息。该答案假设您没有对对话框的默认 PrimeFaces CSS 进行任何更改。实际上,您应该删除任何自定义 .ui-dialog*
选择器,以便让对话框根据答案按预期工作。您还应该不需要 appendToBody="true"
如答案评论中所述。
关于您观察到的问题症状;对话框在 CSS 中有一个默认值 position
fixed
的值,这意味着它相对于视口(viewport)(浏览器的可见区域)定位。换句话说,当您滚动页面时,它不会随页面滚动。对话框只是停留在那里...已修复。当您更改 position
至 absolute
, 那么它将相对于 HTML 文档本身定位。所以,打开对话框后,当你滚动页面时,对话框会随着页面一起滚动。它会准确地停留在您打开对话框时的那个位置。所以如果页面在那一刻向下滚动,对话框也会一直保持向下。
此外,当对话框打开时,PrimeFaces 还会运行一些 JavaScript 代码,以便使对话框在视口(viewport)中正确居中,并在必要时自动调整其大小。你可以通过style
看到它使用固定 CSS 设置的属性 left
和 top
特性。 JavaScript 基于视口(viewport)计算。但是,当您设置 appendToBody="true"
时,该计算显然在 Safari 中失败了。并且它们是以某种方式相对于 HTML 文档的底部进行计算的。
关于css - 对话框显示在页面底部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23349277/
我有一个删除按钮,单击该按钮时我希望弹出一个对话框,然后单击“确定”它应该执行 Ajax 调用,否则不应该执行任何操作。这是代码 $('.comment-delete').click(function
public void exitGame() { //pop up dialogue Platform.exit(); } 我已经尝试了很多我在互联网上看到的不同的东西,但我什么都做不了。我所
我有一个典型的素面对话框,效果很好,但是当有人在对话框外单击时,我找不到任何关闭它的选项。我看到了一些jquery示例,我想我可以将其改编为primefaces对话框,但首先要确保还没有解决方案? 谢
我试图让 jquery 对话框在单击按钮时启动,但似乎不起作用。任何帮助将不胜感激: $('#wrapper').dialog({ autoOpen: false,
我试图单独更改标题栏颜色。所以我使用了 .ui-dialog-titlebar ,但它不起作用,所以我尝试使用 ui-widght-header ,它也反射(reflect)到数据表..请告知。 //
我的页面上有 div(box),我正在使用此脚本将 div 显示为对话框。在该 div 内,我有一个超链接,单击该超链接时,我想淡出对话框并关闭。对话框的内容淡出,但对话框的边框保持不变。如果我将 $
我当前有一个对话框,其内容有两个输入(这两个输入使用 .datepicker())。当我打开对话框时,第一个输入成为焦点,并且第一个日期选择器自动出现。我尝试隐藏 div 并模糊输入,但这会导致日期选
我想即时创建一个 jQuery 对话框。我正在使用这个: var newDiv = $(document.createElement('div')); $(newDiv).html('hello th
child: RaisedButton( color: const Color(0xFF5867DD), onPressed: (){ updateProfilePic();
我有下面的 jquery 代码,我已根据我的要求对其进行了自定义,但存在一些问题。首先,用户单击“单击此处”,不会显示对话框。当用户单击“关闭”时,对话框不会消失。非常感谢您提供的所有帮助。
如何创建一个对话框,该对话框的顶部有一个文本,其下方有一个空白区域,用户可以在其中键入内容,在右侧下方有一个 OKAY 按钮,当您单击该按钮时,对话框消失? 像这样: 最佳答案 String inpu
这是一个简单得多的问题。 private static AplotBaseDialog dlg; public Object execute(final ExecutionEvent event) t
我正在为我的应用程序开发小部件。应该有一些小部件可以实现相同的功能,唯一的区别在于它们的布局(主题/外观) 我会创建一个对话框或屏幕,用户可以在其中选择他喜欢的小部件。当我选择它们时,我在很多小部件中
我有 jQuery 对话框窗口,在某些操作中我有一个加载的 blockUI 插件。 我面临的问题是,即使 AJAX 图像仍在显示,我仍然能够在执行 ajax 操作时执行操作。 另一方面,JSP 页面在
我非常熟悉将 jQuery 对话框 div 设置为可见后将其附加到表单元素的技巧。我已经在 .NET 中这样做了一百次左右,而且效果很好!然而,我正在尝试在 Coldfusion 网站上执行此操作,这
我想使用jquery对话框来收集用户信息(例如用户名)。我如何使用 Jquery 做到这一点并将数据收集到 Javascript 变量中? 这是我迄今为止的尝试: // Dialog here, ho
如何设置 jquery 对话框按钮的工具提示?请参阅下面的内容...这里没有 id 或样式类。 jQuery("#dialog-form").dialog ({ autoOpen: false,
我有调用对话框的 JS 函数 function SomeFunction { $('#editformdialog').dialog('open'); } 这显然已经简化了。但是,我得到 a is u
我正在使用 jquery 模式对话框来显示部分 View 中的数据表。在部分 View 中,我有一些脚本,用于将 HTML 表更改为 jquery DataTables。因此,我需要确保表格在对话框中
我正在尝试添加透明的 JQuery 对话框。但我遇到了两个问题: 文本“Hello”的背景不会变得透明 删除标题栏后,我无法再拖动对话框 这些评论是我迄今为止尝试过的。 //Create ne
我是一名优秀的程序员,十分优秀!