使用Jquery后还能使用JS的原生DOM方法吗?
一个关于JQuery的问题我正在写一个页面,html和js如下:
index.html
<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>The Blog-主页</title>
<link rel="stylesheet" href="./css/base.css">
<link rel="stylesheet" href="./css/nav.css">
<link rel="stylesheet" href="./css/index.css">
<link rel="stylesheet" href="./css/dialog.css">
</head>
<body>
<header>
<nav>
<ul>
<li><img src="./imgs/book.png" alt="书籍图片-用作网页logo" srcset=""></li>
<li><a href="">主页</a></li>
<li><a href="">博文</a></li>
<li><a href="">我的</a></li>
</ul>
</nav>
<section>
<div>
<h1>Test</h1>
<p>
Test
</p>
</div>
</section>
</header>
<section class="register-now">
<div>
<h1>注册!</h1>
<p>Test</p>
<button class="user-dialog-button">注册</button>
</div>
</section>
<dialog class="user-dialog">
<form method="post" action="#">
<h2>注册</h2>
<label for="username">用户名</label>
<input type="text" name="username" id="" />
<br>
<label for="email">邮箱</label>
<input type="text" name="email" id="" />
<br>
<label for="user-password">密码</label>
<input type="password" name="user-password" id="">
<br>
<input type="checkbox" name="user-rules">
<label for="rules">我同意《用户协议》</label>
<br>
<button id="submit" onclick="return false;">注册</button>
</form>
<br>
<button id="change">切换登录</button>
<form method="dialog">
<button id="close-user-dialog">X 关闭</button>
</form>
</dialog>
<footer>
<h3>友情链接</h3>
<ul>
<li><a href="">Example</a></li>
</ul>
</footer>
<script src="./scripts/base.js"></script>
<script src="./scripts/user-dialog.js"></script>
</body>
</html>
user_dialog.js
import jquery from "./jquery";
document.querySelector(".user-dialog-button").addEventListener("click",function set_event() {;
let element = document.querySelector(".user-dialog");
element.showModal();
})
function send_data(){
let json_data = {"username":document.getElementsByName("username").innerText,
"password":document.getElementsByName("password").innerText,
"email":document.getElementsByName("email").innerText
}
if (json_data == "" | json_data == ""| json_data == ""){
alert("数据填写不完整");
return false;
}
$.ajax({
type: "post",
url: "",//我发不了url
data: json_data,
dataType: "json",
success: function (response) {
if (JSON.parse(response)["message"] == "error"){
alert("注册失败");
}
else{
alert("注册成功")
}
}
});
}
document.querySelector("#submit").addEventListener("click",send_data)
然而,我发现只要引入了Jquery,原来JS的DOM好像操作不了或者事件监听用不了,请大佬告诉我这是怎么回事,谢谢!{:5_100:}
以及我Ajax写得可能不对,第一次写233
在你的代码中,当你引入了jQuery之后,确实会覆盖掉一些原生的JavaScript DOM方法和事件监听。这是因为jQuery是一个JavaScript库,它提供了自己的方法和事件处理机制。
在你的代码中,你使用了原生的 document.querySelector 方法来选择元素,并使用 addEventListener 方法来添加事件监听器。然而,当你引入了jQuery之后, document.querySelector 方法将不再起作用,因为jQuery提供了自己的选择器和事件处理方法。
解决这个问题的一种方法是,你可以使用jQuery提供的选择器和事件处理方法来代替原生的方法。例如,你可以使用 $(".user-dialog-button").click(function(){...}) 来替代 document.querySelector(".user-dialog-button").addEventListener("click", function(){...}) 。
另一种方法是,你可以在使用jQuery之前,将jQuery对象转换回原生的JavaScript对象。你可以使用 $() 函数来包装原生的DOM元素。例如,你可以使用 $(document.querySelector(".user-dialog-button")) 来获取一个jQuery对象,然后再使用jQuery提供的方法和事件处理机制。
至于你的Ajax代码,你需要注意几个问题:
1. 在 send_data 函数中,你使用了 document.getElementsByName 方法来获取表单元素的值。然而,这个方法返回的是一个NodeList对象,而不是单个元素。你应该使用 document.getElementsByName("username").value 来获取输入框的值。
2. 在比较json_data的值时,你使用了位运算符 | 来代替逻辑运算符 || 。你应该使用 || 来进行逻辑或操作。
3. 在发送Ajax请求时,你需要提供一个有效的URL。你可以将URL替换为你要发送请求的服务器端地址。
希望这些解释能够帮助你理解问题的原因,并提供了解决问题的方法。如果你有任何疑问,请随时提问。
页:
[1]