
文章目录
我们前面刚刚学习过JS语法,我们可以把JS分为三大部分:
ECMAScript:基础语法
DOM API:操作页面结构
BOM API:操作浏览器
Web API 包含了 DOM + BOM,Web API都是浏览器给js代码提供的功能(如果浏览器不同,api所呈现的行为也可能有所差异)
DOM(Document Object Model):文档对象模型,这里文档指的是html,对象指的是js中的对象,我们可以把html的每个标签都可以映射到js中的每一个对应的对象,js对象修改对应的属性,就可以影响标签的展示
一个网页页面的结构是一个树型结构,我们也成为DOM树,结构如下:

文档:一个页面就是一个文档,使用document表示
元素:网页中的所有标签都成为元素,使用element表示
节点:网页中所有的内容都可以称为 节点(标签节点, 注释节点, 文本节点, 属性节点等). 使用 node表示.
这些概念在JS代码中对应一个个对象
这个工作类似于我们CSS选择器的功能
querySelector 能够复用我们CSS选择器,快捷准确的获取到元素对象
let element = document.querySelector(CSS选择器);
我们来初体验一下querySelector,首先我们准备一个html文件
<div class="a">aaa</div>

大家需要注意:我们在使用querySelector的使用并不是直接使用querySelector,而是使用document调用querySelector,document是浏览器中的全局对象,任何一个页面都会有一个document对象
<script>
let elem = document.querySelector('.a');
console.log(elem);
</script>

如果我们有多个.a那么我们默认选中的是第一个,如果想都选,需要使用querySelectorAll(返回一个数组)

这里针对不同的选择器选择的方式不同

事件就是针对用户的操作进行的一些相应
时间三要素:
事件源:那个元素触发的
事件类型:选中,点击,键盘按下,修改等
事件处理:事件发生之后要执行那个代码
最简单的一个方式:
<div class="a" onclick="alert('hello webapi')">aaa</div>

直接在元素中使用onXXX的方法来绑定一个事件处理程序
<script>
let div = document.querySelector(".a");
div.onclick = function() {
alert("hello");
}
</script>

我们的这里的function匿名函数相当于一个回调函数,不需要我们程序员自己调用,而是浏览器在触发事件时进行调用
1.获取/修改元素内容
首先获取到该元素,使用innerHTML属性拿到元素里的内容,修改该属性,就会影响到界面的显示
<div class="a">aaa</div>
<script>
let div = document.querySelector(".a");
div.onclick = function() {
div.innerHTML = div.innerHTML + 'a';
}
</script>
此处我们每点击一下,末尾就加a

2.获取/修改元素属性
html的属性也会映射到js对象中



console.dir(js对象);
打印Js对象所有属性
3.获取/修改表单元素属性
表单元素(input,textarea,select)这些特别的元素是普通的标签没有的
| 属性 | 作用 |
|---|---|
| value | input的值 |
| type | input的类型 |
<input type="text">
<button>点我一下</button>
<script>
let input = document.querySelector('input');
let button = document.querySelector('button');
button.onclick = function() {
console.log(input.value);
}
</script>
输入框输入什么,我们在控制台打印什么

大家需注意innerHTML与这里的input.value的区别:
innerHTML得到的是标签的内容(开始标签和结束标签中间夹着的内容),input标签是单标签,是没有内容的
我们来实现一个给input里的的数字,每按一次按钮,就给数字+1

我们给Input内输入1,开始按按钮


我们发现并没有加1,因为我们value属性是一个字符串,我们这里变成字符串拼接了,我们这里需要把字符串转成整数(parseInt)
<input type="text">
<button>点我一下</button>
<script>
let input = document.querySelector('input');
let button = document.querySelector('button');
button.onclick = function() {
let value = parseInt(input.value);
value += 1;
input.value = value;
}
</script>

此时就实现功能了
我们的type属性可以实现显示和隐藏密码功能
<input type="password">
<button>显示密码</button>
<script>
let input = document.querySelector('input');
let button = document.querySelector('button');
button.onclick = function() {
if(input.type == 'text') {
input.type = 'password';
button.innerHTML = '显示密码';
}else {
input.type = 'text';
button.innerHTML = '隐藏密码';
}
}
</script>


4.获取/修改样式属性
1.修改内联样式(修改style属性的值)
<div style="font-size: 20px;">
点我放大
</div>
<script>
let div = document.querySelector('div');
div.onclick = function() {
let size = parseInt(div.style.fontSize);
size += 5;
div.style.fontSize = size + 'px';
}
</script>

这里我们需要注意CSS与JS中字体大小属性是有所不同的,CSS是脊柱命名法,我们JS是驼峰命名法。
因为我们在CSS设置的字体大小单位为px,所以我们先转为Int,然后在转回px.
2.修改元素应用的CSS类名
我们这里实现一个切换夜间模式,我们首先先准备两个模式
<style>
.light {
/* 日间模式 */
color: black;
background-color: white;
}
.dark {
/* 夜间模式 */
color: white;
background-color: black;
}
</style>
具体功能实现:
<div class = 'light'>切换夜间模式</div>
<script>
let div = document.querySelector('.light');
div.onclick = function() {
if(div.className == 'dark') {
div.className = 'light';
div.innerHTML = '切换夜间模式';
}else {
div.className = 'dark';
div.innerHTML = '切换日间模式';
}
}
</script>


新增节点一般分为两个步骤:
1.创建元素节点
2.把元素节点插入到DOM树中
使用 createElement 方法来创建一个元素
<script>
let input = document.createElement('input');
input.type = 'text';
input.value = 123456;
console.log(input);
</script>
</body>

使用appendChild 插入到DOM树中
<div class = 'a'>请输入:</div>
<script>
let input = document.createElement('input');
input.type = 'text';
input.value = 123456;
console.log(input);
let div = document.querySelector('.a');
div.appendChild(input);
</script>

appendChild是默认插入在子元素末尾的,insertBefore可以将元素加到指定子元素的前面
使用 removeChild 删除子节点,我们将刚刚加入的input标签删除

返回值为该被删除节点
被删除节点只是从 dom 树被删除了, 但是仍然在内存中, 可以随时加入到 dom 树的其他位置.
如果上例中的 child节点 不是 element 节点的子节点,则该方法会抛出异常.
我们实现一个网页版的猜数字
1.生成一个1 - 100之间的随机数字
2.用户输入一个数字
3.判断用户输入的数字大小关系给出提示
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>猜数字</title>
</head>
<body>
<div>请输入要猜的数字:</div>
<input type="text" >
<button>提交</button>
<!-- 显示提示信息 -->
<div class="result">
</div>
<script>
//生成一个1 - 100之间的随机数
let toGuess = parseInt(100 * Math.random()) + 1;
// 因为Math.rondom()生成的是[0,1)之间的随机数,我们需要进行转换
console.log(toGuess);
//进行猜数字操作
let button = document.querySelector('button');
let input = document.querySelector('input');
let information = document.querySelector('.result');
button.onclick = function() {
//取出输入框内容
if(input.value == '') {
return;
}
let inputNum = parseInt(input.value);
if(inputNum < toGuess) {
information.innerHTML = '猜小了';
}else if(inputNum > toGuess) {
information.innerHTML = '猜大了';
}else {
information.innerHTML = '恭喜你,猜对了!';
}
}
</script>
</body>
</html>



<body>
<h1>表白墙</h1>
<span>谁: </span>
<input type="text">
<span>对谁: </span>
<input type="text">
<span>说: </span>
<input type="text">
<button>提交</button>
</body>

这算什么表白墙,下面的才是我们要实现的

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>表白墙</title>
<style>
* {
/* 消除浏览器默认样式 */
margin: 0;
padding: 0;
box-sizing: border-box;
}
.container {
width: 600px;
margin: 20px auto;
}
h1 {
text-align: center;
}
p {
text-align: center;
color: #666;
margin: 20px auto;
}
.row {
/* 开启弹性布局 */
display: flex;
height: 40px;
/* 水平方向居中 */
justify-content: center;
/* 竖直方向居中 */
align-items: center;
}
.row span {
width: 80px;
}
.row input {
width: 200px;
height: 30px;
}
.row button {
width: 280px;
height: 30px;
color: white;
background-color: orange;
/* 去掉默认边框 */
border: none;
border-radius: 3px;
}
.row button:active {
background-color: black;
}
</style>
</head>
<body>
<div class="container">
<h1>表白墙</h1>
<p>输入内容后点击提交,信息将显示到下方表格</p>
<div class="row">
<span>谁: </span>
<input type="text">
</div>
<div class="row">
<span>对谁: </span>
<input type="text">
</div>
<div class="row">
<span>说: </span>
<input type="text">
</div>
<div class="row">
<button>提交</button>
</div>
</div>
<script>
// 实现将提交的内容呈现在页面显示
let containerDiv = document.querySelector('.container');
let inputs = document.querySelectorAll('input');
let button = document.querySelector('button');
button.onclick = function() {
//分别获取三个输入框的内容
let from = inputs[0].value;
let to = inputs[1].value;
let msg = inputs[2].value;
//构建一个新的div
let rowDiv = document.createElement('div');
rowDiv.className = 'row';
rowDiv.innerHTML = from + ' 对 ' + to + ' 说 ' + msg;
containerDiv.appendChild(rowDiv);
// 完成提交后 情况输入框内的内容
for(let input of inputs) {
input.value = '';
}
}
</script>
</body>
</html>


我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的
我有这个:AccountSummary我想单击该链接,但在使用link_to时出现错误。我试过:bot.click(page.link_with(:href=>/menu_home/))bot.click(page.link_with(:class=>'top_level_active'))bot.click(page.link_with(:href=>/AccountSummary/))我得到的错误是:NoMethodError:nil:NilClass的未定义方法“[]” 最佳答案 那是一个javascript链接。Mechan
我看到有关未找到文件min.map的错误消息:GETjQuery'sjquery-1.10.2.min.mapistriggeringa404(NotFound)截图这是从哪里来的? 最佳答案 如果ChromeDevTools报告.map文件的404(可能是jquery-1.10.2.min.map、jquery.min.map或jquery-2.0.3.min.map,但任何事情都可能发生)首先要知道的是,这仅在使用DevTools时才会请求。您的用户不会遇到此404。现在您可以修复此问题或禁用sourcemap功能。修复:获取文
我有一个用Rails3编写的站点。我的帖子模型有一个名为“内容”的文本列。在帖子面板中,html表单使用tinymce将“content”列设置为textarea字段。在首页,因为使用了tinymce,post.html.erb的代码需要用这样的原始方法来实现。.好的,现在如果我关闭浏览器javascript,这个文本区域可以在没有tinymce的情况下输入,也许用户会输入任何xss,比如alert('xss');.我的前台会显示那个警告框。我尝试sanitize(@post.content)在posts_controller中,但sanitize方法将相互过滤tinymce样式。例如
出于某种原因,我必须为Firefox禁用javascript(手动,我们按照提到的步骤执行http://support.mozilla.org/en-US/kb/javascript-settings-for-interactive-web-pages#w_enabling-and-disabling-javascript)。使用Ruby的SeleniumWebDriver如何实现这一点? 最佳答案 是的,这是可能的。而是另一种方式。您首先需要查看链接Selenium::WebDriver::Firefox::Profile#[]=
我是Ruby和Watir-Webdriver的新手。我有一套用VBScript编写的站点自动化程序,我想将其转换为Ruby/Watir,因为我现在必须支持Firefox。我发现我真的很喜欢Ruby,而且我正在研究Watir,但我已经花了一周时间试图让Webdriver显示我的登录屏幕。该站点以带有“我同意”区域的“警告屏幕”开头。用户点击我同意并显示登录屏幕。我需要单击该区域以显示登录屏幕(这是同一页面,实际上是一个表单,只是隐藏了)。我整天都在用VBScript这样做:objExplorer.Document.GetElementsByTagName("area")(0).click
🎉精彩专栏推荐💭文末获取联系✍️作者简介:一个热爱把逻辑思维转变为代码的技术博主💂作者主页:【主页——🚀获取更多优质源码】🎓web前端期末大作业:【📚毕设项目精品实战案例(1000套)】🧡程序员有趣的告白方式:【💌HTML七夕情人节表白网页制作(110套)】🌎超炫酷的Echarts大屏可视化源码:【🔰Echarts大屏展示大数据平台可视化(150套)】🔖HTML+CSS+JS实例代码:【🗂️5000套HTML+CSS+JS实例代码(炫酷代码)继续更新中…】🎁免费且实用的WEB前端学习指南:【📂web前端零基础到高级学习视频教程120G干货分享】🥇关于作者:💬历任研发工程师,技术组长,教学总监;
我有一个Rails应用程序。还有一个javascript(javascript1.js)文件必须包含在每个View的最底部。我把它放在/assets/javascripts文件夹中。Application.js包含以下代码//=requirejquery//=requirejquery_ujs//=someotherfiles//=require_directory.即使Application.js中不包含javascript1.js,它也会自动包含,不是吗?那么我怎样才能做我想做的事呢? 最佳答案 单独定义、包含和执行您的java
如何生成指向javascript文件的绝对链接。我想应该有类似下面的东西(不幸的是它似乎不可用):javascript_url'main'#->'http://localhost:3000/javascripts/main.js'代替:javascript_path'main'#->'/javascripts/main.js'我需要绝对URL,因为该javascript文件将用于书签。另外我需要相同的css文件。谢谢,德米特里。 最佳答案 javascript和css文件的绝对URL现在在Rails4中可用ActionView::H
我在HTML页面上有一个文本字段,用于检查您是否输入了1到365之间的值。如果用户输入了无效值,如非数字字符或不在范围内的值,它显示一个弹出窗口。我在watirwiki上看到有一个select_no_wait方法,用于在您从列表中选择无效值时关闭弹出窗口。处理键盘事件时出现的弹出窗口的好方法是什么?我是否需要按照select_no_wait方法的实现方式进行操作,或者我们是否可以启动一个不同的进程来消除调用set方法时可能出现的弹出窗口。带有Javascript验证函数的HTML文件示例如下:varnum=0functionvalidate(e){varcharPressed=Stri