- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在根据 w3schools.com 上显示的示例使用选项卡。利用他们的示例,我根据自己的喜好调整了 html 和 css,但我遇到了页面重新加载的问题。我想在页面重新加载时返回到最后选择的选项卡(即事件选项卡),无论是通过点击重新加载按钮还是提交按钮将数据发送到数据库。
下面贴出的javascript首先隐藏标签页内容,然后清除所有事件标签,然后将点击的任何标签设置为事件标签,同时清除之前的事件标签。
我玩过 java 脚本中的选项卡清除代码,但一直遇到这样的问题:当我单击不同的选项卡时不清除事件选项卡,和/或当我点击重新加载时清除所有内容。
所以我开始做一些研究,并在 MDN 上找到了使用 sessionstore() 的选项。 MDN 提供的基本示例完全合理,但将它们应用到此选项卡设计对我来说并不直观。我在用户登录时启动一个 session ,这样就可以利用一个 session 。
我在这个网站上看到了一些与此相关的其他问题,但我无法将这些问题翻译成这个。
不知道我是否在这方面找错了树,但是我想以某种方式将当前选项卡存储在当前 session 中,以便用户在执行操作时返回到该选项卡页面重新加载或点击提交按钮将数据发送/获取到数据库。
我正在摆弄的代码如下:
function openEDO(event, plannerName) {
var i, tabcontent, tablinks;
tabcontent = document.getElementsByClassName("tabcontent");
for (i = 0; i < tabcontent.length; i++) {
tabcontent[i].style.display = "none";
}
tablinks = document.getElementsByClassName("tablinks");
for (i = 0; i < tablinks.length; i++) {
tablinks[i].className = tablinks[i].className.replace(" active", "");
}
document.getElementById(plannerName).style.display = "block";
event.currentTarget.className += " active";
}
document.getElementById("defaultOpen").click()
/* Style the tab */
div.tab {
overflow: hidden;
background-color: #CECECE;
border: 0px solid #003399;
width: 1200px;
}
/* Style the buttons inside the tab */
div.tab button {
background-color: inherit;
color: #003399;
font-family: Helvetica;
float: left;
border: 0px solid;
width: 150px;
height: 50px;
cursor: pointer;
padding: 5px 5px;
transition: 0.3s;
font-size: 15px;
float:left
text-align: center;
font-weight:bold;
}
/* Change background color of buttons on hover */
div.tab button:hover {
background-color: #ffcc00;
color: #003399;
}
/* Create an active/current tablink class */
div.tab button.active {
background-color: #003399;
color: #ffcc00;
}
/* Style the tab content */
.tabcontent {
display: none;
padding: 6px 12px;
animation: fadeEffect 0.3s;
width: 1190px;
}
/* Fade in tabs */
@keyframes fadeEffect {
from {opacity: 0;}
to {opacity: 1;}
<div class="tab">
<button class="tablinks" onclick="openEDO(event, 'Home')" id="defaultOpen">Home</button>
<button class="tablinks" onclick="openEDO(event, 'PI')">Personal Info</button>
<button class="tablinks" onclick="openEDO(event, 'PH')">Professional History</button>
<button class="tablinks" onclick="openEDO(event, 'P1')">Plan 1</button>
<div id="Home" class="tabcontent">
</div>
<div id="PI" class="tabcontent">
</div>
<div id="PH" class="tabcontent">
</div>
<div id="P1" class="tabcontent">
</div>
使用此代码,页面总是在页面加载时返回主页。显然我可以删除它并且没有选项卡成为“默认”页面,或者使其他页面成为页面重新加载时的默认页面。但我想要的是能够返回到当前 session 中的最后一个选项卡。我还想保留当前用户首次登录并开始新 session 时从主页开始的功能。
如果有人能帮我解决这个问题,我将永远感激不尽。
最佳答案
使用sessionStorage
,为每个按钮添加id,在页面加载时检查sessionStorage是否已经设置?如果是,请单击事件按钮。否则,单击默认主页按钮:
在您的函数 openEDO
中首先使用以下方法设置 sessionStorage:
sessionStorage.setItem('sel_tab', plannerName);
JS:
var seltab = sessionStorage.getItem('sel_tab');
if (seltab) {
document.getElementById("Btn" + seltab).click();
} else {
document.getElementById("BtnHome").click();
}
HTML:
<button class="tablinks" id="BtnHome" onclick="openEDO(event, 'Home')">Home</button>
<button class="tablinks" id="BtnPI" onclick="openEDO(event, 'PI')">Personal Info</button>
<button class="tablinks" id="BtnPH" onclick="openEDO(event, 'PH')">Professional History</button>
<button class="tablinks" id="BtnP1" onclick="openEDO(event, 'P1')">Plan 1</button>
Window.sessionStorage
REF:https://developer.mozilla.org/en/docs/Web/API/Window/sessionStorage
关于Javascript,重新加载时返回上一个选项卡,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44193443/
在 Android 的 API > 19 中是否有任何方法可以获取可移动 SD 卡的路径? 与外部 SD 卡一样,我们有 Environment.getExternalStorageDirectory
一些 Android 设备有 microSD(或其他存储卡)插槽,通常安装为 /storage/sdcard1 据我所知,自 Android 4.4 起 Google 限制了对此内存的访问,并在 An
我使用 Java Card 2.1.2 SDK 和 GPShell 作为与设备通信的方式在 Java Card 上构建一个项目。我从 GpShell 测试了 helloworld 示例,并成功发送了
我开发了一个应用程序,它有一个来电接收器,它适用于所有手机。一位用户有一部双 SIM 卡安卓手机。该应用程序适用于第一张 SIM 卡。但是当有人调用他的第二张 SIM 卡时,我们的应用程序不会被调用。
我有一个带预览的文件输入。 这是笔 Codepen 我想强制高度,我无法理解我该怎么做。我想将此组件的高度固定为 300px(示例),我还需要保持加载图像的正确纵横比,用灰色背景填充空白。现在我保持宽
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我正在使用此代码访问 SD card : import os from os.path import join from jnius import autoclass #from android.pe
我正在为数据记录设备编写固件。它以 20 Hz 的频率从传感器读取数据并将数据写入 SD 卡。但是,向SD卡写入数据的时间并不一致(大约200-300 ms)。因此,一种解决方案是以一致的速率将数据写
我正在使用以下代码将视频放到网站上,但是在垂直方向上,手机屏幕上只能看到视频的左半部分 我不是网络开发人员。有人可以告诉我确切的内容吗,如何使其正确放置在手机屏幕上? 是在youtube iframe
我正在使用 Vuetify 1.5 和 Vuetify 网格系统来设置我的布局。现在我有一个组件 HelloWorld我将其导入到我的 Parent 中成分。我已经在我的 HelloWorld 中设置
我使用 python 制作了一个简单的二十一点游戏。我制作了游戏的其余部分,但我正在努力放入 ASCII 卡,所以这只是代码的一小部分。我尝试将 * len(phand) 放在附加行的末尾。虽然这确实
我正在使用玩家卡设置 Twitter 卡。它可以在预览工具中运行,但文档说它需要在“twitter.com 现代桌面浏览器? native iOs 和 Android Twitter 应用程序?mob
任何旧的 GSM 兼容 SIM 卡(3G USIM 的奖励)。 我想我需要一些硬件?谁能为业余爱好者推荐一些便宜的东西,以及一些更专业的东西? 我认为会有一个带有硬件的 API 的完整文档,所以也许这
我使用 python 制作了一个简单的二十一点游戏。我制作了游戏的其余部分,但我正在努力放入 ASCII 卡,所以这只是代码的一小部分。我尝试将 * len(phand) 放在附加行的末尾。虽然这确实
我记得前一段时间读到有 cpu 卡供系统添加额外的处理能力来进行大规模并行化。任何人都有这方面的经验和任何资源来研究项目的硬件和软件方面吗?这项技术是否不如传统集群?它更注重功率吗? 最佳答案 有两个
我检查外部存储是否已安装并且可用于读/写,然后从中读取。我使用的是确切的官方 Android 示例代码 ( from here )。 它说外部存储未安装。 getExternalFilesDir(nu
在 Android 2.1 及更低版本中,Android 应用程序可以请求下载到 SD 卡上吗?另外我想知道应用程序是否可以请求一些包含视频的文件夹下载到 SD 卡上?以及如何做到这一点? 提前致谢。
我们编写了一个 Windows 设备驱动程序来访问我们的自定义 PCI 卡。驱动程序使用 CreateFile 获取卡的句柄。 我们最近在一次安装中遇到了问题,卡似乎停止工作了。我们尝试更换卡(更换似
有些新设备(例如 Samsung Galaxy)带有两个 SD 卡。我想知道是否有任何方法可以确定设备是否有两张 SD 卡或一张 SD 卡。谢谢 最佳答案 我认为唯一的方法是使用 检查可用根的列表 F
我正在尝试将文件读/写到 SD 卡。我已经尝试在我的真实手机和 Eclipse 中的模拟器上执行此操作。在这两种设备上,对/mnt/sdcard/或/sdcard 的权限仅为“d--------”,我
我是一名优秀的程序员,十分优秀!