- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 CodeIgniter、jQuery 等开发一个应用程序。它有一个页面,其中有 3 个表单用于登录、注册和忘记密码。所有这些都位于一个页面中。
默认显示登录页面(登录表单),单击“注册”后,将显示注册表单而无需重新加载。我通过在 View 中为每个表单制作不同的部分然后使用 jquery 调用该部分来实现此目的,这使注册表单显示和隐藏登录表单,并且有一个后退按钮可以让我返回登录页面。
代码是:
jQuery('#register-form').click(function () {
jQuery('.login-form').hide();
jQuery('.forget-form').show();
});
jQuery('#back-btn').click(function () {
jQuery('.login-form').show();
jQuery('.forget-form').hide();
});
我想知道如何使 url 正常运行,以便我可以通过访问它的 url 来访问每个表单。
例如,example.com/#register-form 会直接带我到我的注册表格,同样通过单击后退按钮,我的 url 应该像 getbootstrap.com 一样适本地改变工作。忘记密码也是如此。
我尝试了 jquery-hashchange 插件,但无法弄清楚具体方法。任何人都可以告诉我在没有任何插件帮助的情况下完成此任务的正确方法吗?如果必须使用插件,请推荐一个。
最佳答案
好的,如果我对您的理解是正确的,您希望根据按钮点击或使用散列标记的 URL 本身动态显示或隐藏正确的表单。而且,如果可能的话,您不希望借助插件。
假设我正确理解了这一点,那么下面的代码可能与您正在寻找的内容一致。请注意,我没有在示例中放置所有错误处理等,但我相信这里有足够的内容可以帮助您“启动”您正在寻找的方向。
一些初始的 jquery/javascripting 来设置一切。
var urlHref = window.location.href;
var urlHostName = window.location.hostname;
var urlPathName = window.location.pathname;
var urlHashParam = urlHref.split("#");
$(document).ready(function() {
$("#hostName").html(urlHostName);
$("#pathName").html(urlPathName);
$("#hostHref").html(urlHref);
$("#hashTag").html(urlHashParam[1]);
switch(urlHashParam[1]) {
case "register":
manageForms("register");
break;
case "forgot":
manageForms("forgot");
break;
default:
manageForms("login");
}
$('#btnRegister').click(function() {
manageForms("register");
});
$('#btnLogin').click(function() {
manageForms("login");
});
$('#btnForgot').click(function() {
manageForms("forgot");
});
});
function manageForms(visibleForm) {
$("#login").hide();
$("#register").hide();
$("#forgot").hide();
$("#" + visibleForm).show();
if (history.pushState) {
// only works if the browser supports pushState.
window.history.pushState("test", "Title", urlPathName + "#" + visibleForm);
}
}
基本上我们在这里所做的是获取 windows.login 的不同属性,以便我们可以获得我们正在寻找的值。
我们在切换期间默认使用登录表单(因为如果 url 中没有请求散列标签或请求的散列标签未知,您首先需要那个)
您还要求在不重新加载表单的情况下动态修改 URL(如果通过单击按钮选择,则使用新标记)。这在现代浏览器中是可能的,但在旧浏览器中则不然。这是由
if (history.pushState) {
// only works if the browser supports pushState.
window.history.pushState("test", "Title", urlPathName + "#" + visibleForm);
}
因为并非所有浏览器都支持它,所以在使用该命令之前会快速检查是否支持。
最后是此代码测试的 HTML 部分。
HREF: <span id="hostHref"></span>
<br>
Host Name: <span id="hostName"></span>
<br>
Path Name: <span id="pathName"></span>
<br>
Hash Tag Parameters: <span id="hashTag"></span>
<br>
<hr>
<input type="button" id="btnLogin" value="Login">
<input type="button" id="btnRegister" value="Register for Access">
<input type="button" id="btnForgot" value="Forgot Password">
<hr>
<div id="login">
This is the Login Section
</div>
<div id="register">
This is the Register Section
</div>
<div id="forgot">
This is the forgot password section
</div>
希望至少其中的一些内容有所帮助。
关于javascript - 如何为单页 jQuery 登录、注册和忘记密码表单适当更改 url,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25444109/
我有一个问题,想知道如何在已经使用常规登录/注册系统的网站上集成第 3 方登录(也进行静默注册)。 基本上当前登录还是比较规律的: 当用户进入网站 session 时类(class)决定他是否需要重新
我在学习 Hyperledger Fabric 并运行示例代码。 我仍在尝试正确了解事情的运作方式,尤其是在使用证书和加密 Material 的用户/管理员注册和注册中。 我想知道以下如何工作。 1)
我正在尝试使用从我的 Android 设备的 PassWallet 应用程序中保存的票证中获取的 token 向我的设备发送消息。 设备发送使用苹果钱包规范更新通行证所需的所有信息。但是,我正在使用
使用 Passport 本地示例,我可以登录工作。没有关于如何注册用户的文档。 我想为用户提供一个“电子邮件”和“密码”字段,他们可以使用它们来注册该网站。我怎样才能做到这一点?有什么原因没有记录下来
在之前的一些 WSO2IS 版本中,有一个默认的 self 注册功能。但是,我在 5.0 版本中找不到它。 阅读 WSO2IS 5.0 文档,我发现有 2 个用于此功能的 API: getUserId
我已将 Airship SDK 集成到 Android 应用程序中。在应用程序启动和飞艇起飞后,我在日志中得到以下调试信息: 07-27 12:46:31.916 XXX - UALib( 1545)
Delphi 中设计时包的可怕错误之一是以下错误,这意味着注册安装新组件到您的 Palette 上的包: Component TSomething can't be registered by pac
我发现的大部分内容都使用 php 或类似的东西。 我有一个 Angular 前端和 Node/express 服务器代码。还没有后端。我不确定如何继续用户注册。 最佳答案 在没有后端的情况下进行注册等
我正在使用 Drupal 6 开发一个网站。我正在使用我自己的主题,并且一切正常。现在我需要使用我的自定义主题在我的网站上创建一个自定义登录/注册表单。我尝试了很多方法,但一切都重定向到我的管理主题,
我在运行此代码时收到 Sip 异常。这是因为 manager.register(me,20,listener)。 下面是我的代码,所以请帮我更正这段代码。我正在使用 SipDemo 代码注册我的帐户。
在过去的几天里,我一直在尝试为基于 VUE 的 excel 制作任务 Pane 插件。 我已按照 link 的指南进行操作我试图为 onSelectionChange 注册一个事件处理程序。它已经有些
我需要在使用 django-registration 应用程序的登录表单中实现一个“记住我”按钮。任何ane可以帮助我向我展示这样做的方法吗? 谢谢 最佳答案 一种方法是更改 session 到期
我发现,如果您使用 Django 1.5 版本,则 django 注册模块会中断,因为在最新的 django 开发版本中,simple.py 类已被删除。 最佳答案 此问题现已修复: hg clone
我正在尝试将 facebook connect 实现到我的网站,但有几个问题。 1:是否可以使用用户当前的 Facebook 电子邮件/密码在我的网站上注册用户。 假设用户点击链接通过 faceboo
我使用 Facebook 注册来允许人们在我的网站上注册。有没有可能,在注册后,他在我的网站注册的成员(member)墙上会张贴? 最佳答案 这可能不是您正在寻找的答案,但我强烈建议您不要这样做。用户
I would like to use a slash (/) for a search during a vimscript, but I don't want to overwrite the "
我正在使用 jqgrid 并且有显示日期的列,但是来自服务器的日期以 json 格式出现,如下所示, "CommentedDate": "\/Date(1304324941000+0530)\/" 如
我希望用户可以直接登录主页,而不是在“../account/login/”页面上登录。我应该做什么才能使它成为可能?如何将主页上的输入字段与 allauth 连接?我不知道这样是否太复杂而无法以这种方
This question already has answers here: Understanding NSString comparison (7个答案) 5年前关闭。 我正在尝试制作注册表。有
我正在使用 Django 注册。它提供了处理 registration_form.html 的 View ,该 html 当前包含用户名、密码 1、密码 2 和电子邮件作为我的应用程序中的用户可输入字
我是一名优秀的程序员,十分优秀!