HTML页面之间跳转与传值(JS代码)

HTML页面之间跳转与传值(JS代码)

跳转的方法如下:

  • 方法一:
window.location.href = "b.html";
  • 方法二(返回上一个页面,这个应该不算,先放在这):
window.history.back(-1);
  • 方法三:
self.location = "b.html";
  • 方法四:
top.location = "b.html";

有关问题的思考:
第一,为什么给window.location和window.location.href赋值时一样的,都可以跳转?
思考:
location 是 location.href 的简写,无论是访问还是赋值。
从功能上,location 等于 location.href;
但从本体理论上,location 是一個对象,location.href 是它的一个属性。

第二,给location赋值的时候,如果跳转的页面不是在同一个目录下,需要把完整的URL写上。如:当前location.href为https://www.google.com/ ,如果要跳转到https://www.baidu.com/, 就不能只是www.baidu.com,必须把URL写完整。
传值的方法如下:

  • 方法一:URL传参(?后面的参数)(去哪儿网笔试题,把URL后面的参数解析为对象)
window.location.href = "https://www.google.com/search?q=hello&oq=hello"
function parseURL(url){
    var url = url.split("?")[1];
    var para = url.split("&");
    var len = para.length;
    var res = {};
    var arr = [];
    for(var i=0;i<len;i++){
        arr = para.split("=");
        res[arr[0]] = arr[1];
    }
    return res;
}
  • 方法二:cookie传参
function setCookie(cname,cvalue,exdays){
    var d = new Date();
    d.setTime(d.getTime() + (exdays*24*60*60*1000));
    var expires = "expires=" + d.toUTCString();
    document.cookie = cname + "=" + cvalue + "; " + expires;
}

function getCookie(cname){
    var name = cname + "=";
    var ca = document.cookie.split(";");
    for(var i=0;i<ca.length;i++){
        var c = ca[i];
        while(c.charAt(0)==' '){
            c = c.substring(1); 
        }
        if(c.indexof(cname) == 0){
            return c.substring(name.length,c.length);
        }
    }
    return "";
}
  • 方法三:H5中Web Storage中的localStorage对象
function Open()
{
    localStorage.clean();//清空LocalStorage
    localStorage.setItem("name","Anakin");
    window.Open("a.html","_blank");
}

或者

localStorage.name= "Anakin";

a.html取值


<script type="text/javascript">

    //取值
    var name=localStorage.getItem("name");
    alert(name);

</script>

弹出的消息即为Anakin
或者

localStorage.lastname;

下面为详细介绍
这里推荐使用h5方法

我首先在开发者工具的Console中,输入了

localStorage.
然后就弹出了一些列宿主(浏览器)提供的localStorage自带的方法,摘录了一些常用的API如下表所示:

这里写图片描述
清空数据

localStorage.clear()    // undefined    
localStorage            // Storage {length: 0}

存储数据

localStorage.setItem("name","caibin") //存储名字为name值为caibin的变量
localStorage.name = "caibin"; // 等价于上面的命令
localStorage // Storage {name: "caibin", length: 1}

读取数据

localStorage.getItem("name") //caibin,读取保存在localStorage对象里名为name的变量的值
localStorage.name // "caibin"
localStorage.valueOf() //读取存储在localStorage上的所有数据
localStorage.key(0) // 读取第一条数据的变量名(键值)
//遍历并输出localStorage里存储的名字和值
for(var i=0; i<localStorage.length;i++){
    console.log('localStorage里存储的第'+i+'条数据的名字为:'+localStorage.key(i)+',值为:'+localStorage.getItem(localStorage.key(i)));
}

删除某个变量

localStorage.removeItem("name"); //undefined
localStorage // Storage {length: 0} 可以看到之前保存的name变量已经从localStorage里删除了

检查localStorage里是否保存某个变量

// 这些数据都是测试的,是在我当下环境里的,只是demo哦~
localStorage.hasOwnProperty('name') // true
localStorage.hasOwnProperty('sex')  // false转为本地字符串

将数组转为本地字符串

var arr = ['aa','bb','cc']; // ["aa","bb","cc"]
localStorage.arr = arr //["aa","bb","cc"]
localStorage.arr.toLocaleString(); // "aa,bb,cc"JSON存储到localStorage里

var students = {
    xiaomin: {
        name: "xiaoming",
        grade: 1
    },
    teemo: {
        name: "teemo",
        grade: 3
    }
}

students = JSON.stringify(students);  //将JSON转为字符串存到变量里
console.log(students);
localStorage.setItem("students",students);//将变量存到localStorage里

var newStudents = localStorage.getItem("students");
newStudents = JSON.parse(students); //转为JSON
console.log(newStudents); // 打印出原先对象

说一下这个纠结的东西:简单说是跨js传递json值,通过localStorage中转,有种压缩和解压缩的味道在。其实应该有个公共的变量.js放在最前面,会不会更好呢。我好像是在这样一个场景下用到的:后台传递json格式的经纬度给前台,前台让它在地图上渲染出来,而且是两个不同的js文件传递,然后就使用了这个方法。不过现在想想应该有其它更好的解决方法吧。

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我可以提供一些示例代码供您参考。请注意,这些代码只是示例,需要根据实际情况进行调整。 1. 创建数据库和用户表 在 MySQL 中创建一个名为“email”的数据库,并创建一个名为“users”的表,包含以下字段: ```sql CREATE TABLE `users` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(255) NOT NULL, `password` varchar(255) NOT NULL, `email` varchar(255) NOT NULL, `created_at` datetime NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; ``` 2. 注册页面 ```html <!DOCTYPE html> <html> <head> <title>注册页面</title> </head> <body> <h1>注册页面</h1> <form action="register.php" method="post"> <label for="username">用户名:</label> <input type="text" name="username" id="username" required><br> <label for="password">密码:</label> <input type="password" name="password" id="password" required><br> <label for="confirm_password">确认密码:</label> <input type="password" name="confirm_password" id="confirm_password" required><br> <label for="email">邮箱:</label> <input type="email" name="email" id="email" required><br> <input type="submit" value="注册"> </form> </body> </html> ``` 在 register.php 文件中,我们需要对用户提交的数据进行验证,并将其添加到“users”表中: ```php <?php // 连接数据库 $host = 'localhost'; $username = 'root'; $password = ''; $dbname = 'email'; $conn = new mysqli($host, $username, $password, $dbname); if ($conn->connect_error) { die('连接失败:' . $conn->connect_error); } // 处理用户提交的数据 $username = $_POST['username']; $password = $_POST['password']; $confirm_password = $_POST['confirm_password']; $email = $_POST['email']; // 验证用户名和邮箱是否已被注册 $sql = "SELECT * FROM users WHERE username='$username' OR email='$email'"; $result = $conn->query($sql); if ($result->num_rows > 0) { echo '用户名或邮箱已被注册'; } else { // 验证密码和确认密码是否一致 if ($password !== $confirm_password) { echo '密码和确认密码不一致'; } else { // 添加用户到数据库 $created_at = date('Y-m-d H:i:s'); $sql = "INSERT INTO users (username, password, email, created_at) VALUES ('$username', '$password', '$email', '$created_at')"; if ($conn->query($sql) === TRUE) { echo '注册成功'; } else { echo '注册失败:' . $conn->error; } } } // 关闭数据库连接 $conn->close(); ?> ``` 3. 登录页面 ```html <!DOCTYPE html> <html> <head> <title>登录页面</title> </head> <body> <h1>登录页面</h1> <form action="login.php" method="post"> <label for="username">用户名:</label> <input type="text" name="username" id="username" required><br> <label for="password">密码:</label> <input type="password" name="password" id="password" required><br> <input type="submit" value="登录"> </form> </body> </html> ``` 在 login.php 文件中,我们需要验证用户名和密码是否正确,并使用 session 保存用户信息: ```php <?php session_start(); // 连接数据库 $host = 'localhost'; $username = 'root'; $password = ''; $dbname = 'email'; $conn = new mysqli($host, $username, $password, $dbname); if ($conn->connect_error) { die('连接失败:' . $conn->connect_error); } // 处理用户提交的数据 $username = $_POST['username']; $password = $_POST['password']; // 验证用户名和密码是否正确 $sql = "SELECT * FROM users WHERE username='$username' AND password='$password'"; $result = $conn->query($sql); if ($result->num_rows > 0) { // 保存用户信息到 session $_SESSION['username'] = $username; $_SESSION['password'] = $password; echo '登录成功'; } else { echo '用户名或密码错误'; } // 关闭数据库连接 $conn->close(); ?> ``` 4. 邮箱页面 ```html <!DOCTYPE html> <html> <head> <title>邮箱页面</title> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script> <script> $(document).ready(function() { // 每隔 5 秒钟自动刷新邮件列表 setInterval(function() { $('#email-list').load('email-list.php'); }, 5000); }); </script> </head> <body> <h1>欢迎,<?php echo $_SESSION['username']; ?></h1> <a href="logout.php">注销</a> <h2>邮件列表</h2> <div id="email-list"> <?php include 'email-list.php'; ?> </div> </body> </html> ``` 在 email-list.php 文件中,我们可以从数据库中获取邮件列表,并使用正则表达式解析邮件内容: ```php <?php // 连接数据库 $host = 'localhost'; $username = 'root'; $password = ''; $dbname = 'email'; $conn = new mysqli($host, $username, $password, $dbname); if ($conn->connect_error) { die('连接失败:' . $conn->connect_error); } // 获取邮件列表 $username = $_SESSION['username']; $sql = "SELECT * FROM users WHERE username='$username'"; $result = $conn->query($sql); if ($result->num_rows > 0) { $row = $result->fetch_assoc(); $email = $row['email']; // 模拟邮件列表 $emails = array( array( 'sender' => 'test@test.com', 'subject' => '测试邮件', 'body' => '这是一封测试邮件。', 'date' => '2021-07-01 10:00:00', ), array( 'sender' => 'example@example.com', 'subject' => '示例邮件', 'body' => '这是一封示例邮件。', 'date' => '2021-07-01 11:00:00', ), ); // 显示邮件列表 foreach ($emails as $email) { echo '<div>'; echo '<strong>发件人:</strong>' . $email['sender'] . '<br>'; echo '<strong>主题:</strong>' . $email['subject'] . '<br>'; echo '<strong>时间:</strong>' . $email['date'] . '<br>'; echo '<a href="email.php?sender=' . urlencode($email['sender']) . '&subject=' . urlencode($email['subject']) . '">查看</a>'; echo '</div>'; } } else { echo '用户不存在'; } // 关闭数据库连接 $conn->close(); ?> ``` 在 email.php 文件中,我们可以从 URL 参数中获取邮件内容,并使用正则表达式解析邮件内容: ```php <?php // 获取 URL 参数 $sender = urldecode($_GET['sender']); $subject = urldecode($_GET['subject']); // 解析邮件内容 $body = ''; if (preg_match('/From: (.*)\r\n/', $email, $matches)) { $body .= '<strong>发件人:</strong>' . $matches[1] . '<br>'; } if (preg_match('/Subject: (.*)\r\n/', $email, $matches)) { $body .= '<strong>主题:</strong>' . $matches[1] . '<br>'; } if (preg_match('/Date: (.*)\r\n/', $email, $matches)) { $body .= '<strong>时间:</strong>' . $matches[1] . '<br>'; } if (preg_match('/\r\n\r\n(.*)/', $email, $matches)) { $body .= '<strong>内容:</strong>' . nl2br($matches[1]) . '<br>'; } // 显示邮件内容 echo $body; ?> ``` 5. 注销功能 在 logout.php 文件中,我们可以使用 session_destroy() 函数销毁 session,实现注销功能: ```php <?php session_start(); session_destroy(); header('Location: login.php'); ?> ``` 以上就是一个基本的邮箱网站的实现,包括注册登录、邮箱页面、邮件列表、邮件内容和注销功能。当然,具体的实现方式还需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值