- 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"
我有一个页面,我需要在其中单击右侧和左侧的链接,并显示模态对话框。我在 bootstrap 的网站上看到每个模式对话框的代码至少有 10 行 html。如果我在页面上有 10 个链接,那么获得 10 个对话框的代码的最佳做法是什么?我是否将对话框的所有 HTML 放在同一个 .html 页面中?
最佳答案
为了扩展 Phoenix 给出的答案,内联意味着您是否希望在页面加载时加载内容并且易于访问。所以你会把所有 10 个模态框都放在页面上,这样当页面加载时内容就已经存在了,然后你只需单独链接到每个模态框。
因此,无论您选择什么,您都可以放置 10 个按钮或链接,并将 data-target 属性放置到相应的模式中,如下所示:
<!-- Trigger the modal with a button -->
<button type="button" class="btn btn-info btn-lg" data-toggle="modal" data-target="#myModal">Open Modal</button>
然后您将放置 10 个具有不同 ID 的模态框,如下所示。
<!-- Modal -->
<div id="myModal" class="modal fade" role="dialog">
<div class="modal-dialog">
<!-- Modal content-->
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">×</button>
<h4 class="modal-title">Modal Header</h4>
</div>
<div class="modal-body">
<p>Some text in the modal.</p>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
</div>
</div>
</div>
</div>
如果您希望搜索引擎为模态框的内容编制索引,并且您希望模态框易于访问并快速加载,这将是最好的选择。
或者您可以只在页面上放置一个模式并通过 ajax 远程加载所有内容。
所以你的链接看起来像
<a data-toggle="modal" href="Path/To/Code/Snippet" data-remote="Path/To/Code/Snippet" data-target="#myModal">Modal</a>
您只需在页面上放置一个模式,然后通过该模式加载所有内容。您可以将您的 html 片段命名为 myhtmlsnippet.php,并将其放入 href 和 data-remote 属性中。然后只有 html 片段将被加载到一个模态的模态主体中。
然后您应该添加以下脚本,以便每次关闭模式时,它都会清除模式中的内容。
<script>
$(document).on('hidden.bs.modal', function (e) {
var target = $(e.target);
target.removeData('bs.modal')
.find(".modal-body").html('');
});
</script>
这对视频之类的东西很有用。如果您有 10 个不同的视频要加载,那么加载页面将花费过多的时间。但是搜索引擎不会将此远程加载的内容与您的链接所在的页面相关联,它们将单独搜索它们,从那时起您将希望使用 robots.txt 让它们不为这些片段编制索引。
您还可以制作完整的 html 页面,然后从该页面动态加载一个 div 到您的模式中。这对 seo 更好,您不必使用 robots.txt 排除内容。下面是一个带有工作示例的完整 html 页面。除非你在服务器上工作,否则这些显然不起作用,因为服务器加载了 ajax,但你可以复制并粘贴它们以查看它们的工作。此外,您还需要像我在下面所做的那样重组模态,并像我在下面所做的那样重新设置它的样式,因为 Bootstrap 将其模态的远程加载加载到模态内容中。我还将类 clearable-content 添加到 modal-content 并更改了 jquery 脚本,因此如果页面上有其他模式,它不会清除它们的内容,只是动态加载的内容。这是一个工作示例。
<!DOCTYPE html>
<html lang="en">
<head>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
<style>
.modal-title {
text-align:center;
font-size:20px;
font-weight:bold;
}
@media screen and (min-width: 768px){
#myModal .modal-dialog {
webkit-box-shadow: 0 5px 15px rgba(0,0,0,.5);
box-shadow: 0 5px 15px rgba(0,0,0,.5);
}
}
#myModal .modal-header {
border-radius: 5px 5px 0 0;
background-color:#fff;
}
#myModal .modal-content {
background-color:#fff;
border-radius: 0;
padding:20px;
box-shadow: none;
background-clip:inherit;
}
#myModal .modal-footer {
background-color:#fff;
border-radius: 0 0 5px 5px;
}
</style>
</head>
<body>
<!-- Modal -->
<div id="myModal" class="modal fade" role="dialog">
<div class="modal-dialog">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">×</button>
<p class="modal-title">My Dynamic Modal</p>
</div>
<!-- Modal content-->
<div class="modal-content clearable-content">
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
</div>
</div>
</div>
<a data-toggle="modal" href="2.html" data-remote="1.html #modal-section" data-target="#myModal">Page 1 Modal Content</a>
<br /><br />
<a data-toggle="modal" href="3.html" data-remote="2.html #modal-section" data-target="#myModal">Page 2 Modal Content</a>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
<script>
$(document).on('hidden.bs.modal', function (e) {
var target = $(e.target);
target.removeData('bs.modal')
.find(".clearable-content").html('');
});
</script>
</body>
</html>
然后您将制作另一个 html 页面,如下所示,我在上面的链接中将其命名为 1.html,但您可以将其命名为任何名称,只需在主页的链接中更改它即可。
<!DOCTYPE html>
<html lang="en">
<head>
</head>
<body>
<p>Some Other Page Content</p>
<div id="modal-section">
My modal content
</div>
</body>
</html>
这种方法对于 seo 比创建片段要好一些,如果搜索引擎索引了您的网站,他们可以索引您的模态内容,当人们链接到它时,他们将看到一个完整的页面。他们仍然不会将您的模态内容与原始页面相关联,但他们会跟踪链接并单独为页面编制索引。
我希望这能为您解决所有问题。
关于html - 在一个页面中使用多个模态对话框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34427926/
假设我有父页面。 当我单击“打印”时,会打开一个新选项卡(页面)以进行打印预览。 我想要的是,当我单击“打印”时,父选项卡(页面)上应显示覆盖层,以停止进一步的工作,直到子选项卡关闭。 Because
我知道这是不可能的,但我想我还是会问这个问题。 我有一个 HTTPS 页面,并且正在动态创建一个表单。我想将表单发布到 HTTP 页面。在浏览器不弹出警告的情况下这可能吗?当我在 IE8 上执行此操作
在我的应用程序中,我实现了ajax 4.0客户端模板 目前我的模板位于同一个.aspx页面上。 (例如 Main.aspx) 但我想将它们外部化。(即所有 HTML 都会放在另一个页面上) 为此,我使
我目前正在构建自己的网络应用程序。在此应用程序的标题中有一个导航栏。 我将相同的导航栏添加到我的所有 html 页面,以便在页面之间导航时保持可见,并将导航元素设置为事件到我现在所在的页面。 我的
我们有一个在集成管道下运行的 IIS7 Intranet 站点,该管道主要是 ASP.Net,带有一些传统的经典 ASP 页面。该站点允许匿名访问大多数区域,但使用 Windows 身份验证来保护某些
有一个要求,我需要根据 div 标签的高度超过 700 像素的条件将大型 HTML 页面拆分为多个页面。 我还可以根据字数拆分页面。 下面的示例根据 HTML 标签分割页面,而我需要根据 div 高度
有两个 html 页面,如果在第一个页面中单击特定图像,它将转到第二个 html 页面。如果在第二个 html 页面上的任何地方单击它应该返回到第一页并将第二页完全显示在第一页的一个 div 中 1s
我有一个简单的 hello world Servant 应用程序。我需要向它添加一些静态或动态的 html 页面。我怎样才能做到这一点?在文档中没有提到它。注意我不想在 Haskell 代码中创建 h
我有两个文件 index.html 和 index2.html。这两个文件都在本地机器上的同一目录中(无法访问 PHP 等)。 我正在努力 Page Title 使用 jQuery 从 index.h
假设我有一个 JSP 页面 index.jsp User id:
我面临着一个对我来说非常陌生的情况。我会尽力让事情变得简单来解释它一步一步来。 1)在页面 A(用户表单)中,我从字段中获取一些值并将其作为 jQuery AJAX POST 发送到页面 B。这是主要
我正在尝试弄清楚如何从 buttons.html 获取用户按钮点击动态切换第二个列的可见性 userinput.html 。我正在使用 DataTables userinput.html表并认为我有
我有asp。净 mvc4 项目。 Angularjs 已集成。 我已经按照以前的要求构建了 HTML 页面和 WEB API 2。 现在出于某种原因,我必须使用 CSHTML 页面。以前我只有 web
我的网站包含大约 18 个不同的页面。以管理员身份登录后,我单击“页面”。 我看到了以下内容 All (20) | Mine (19) | Published (19) | Draft (1) No
Haskell 中每个函数都有手册页吗?换句话说,我可以在某处输入 man fst 并获取有关该函数的手册或帮助页面吗?我发现大量的功能势不可挡! 我正在使用 GHC 和 GHCi。 最佳答案 我不知
我一直在用github pages很长一段时间以来,并使用自定义域重定向功能来重定向我的 user website来自 prahladyeri.github.io到我自己的域名 https://www
我对 Github 有一个基本的了解:我知道如何创建、添加、提交、推送和克隆存储库。我也开始探索 Github 页面来托管我的项目。我的最新项目于 3 月开始并将其推送到 gh-page。从那以后,我
在尝试查看日志时,Airflow 会抛出一个带有以下消息的 oops 页面: File "/Users/user/.pyenv/versions/3.5.2/lib/python3.5/locale.
我已经按照此处列出的步骤 (https://pages.github.com/) 为我正在处理的网站设置了一个 GitHub 页面 我设置的站点当前托管在 IIS 下,并使用 URL Rewrite
我想将我的 domain.com 重定向到 openshift 页面 (openshift-app.rhcloud.com)。我已经按照描述完成了 here它有效。唯一的问题是,在任何网站上,我都不会
我是一名优秀的程序员,十分优秀!