- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
代码如下:
var listener = document.querySelectorAll('#calculator span');
// look at each widget pressed and update calculator
for (var count = 0; count < listener.length; count++) {
listener[count].onclick = function() {
update()
};
}
function update() {
// Get input of calculator screen and button pressed
var widget = this.innerHTML;
var screen = document.querySelector('.screen');
var screenIn = screen.innerHTML;
// clear the screen
if (widget == 'DEL') {
screen.innerHTML = '';
}
// if = sign is pressed, evaluate the screen input
// TODO: handle special cases (like if the input equation isn't syntactically correct)
else if (widget == '=') {
screen.innerHTML = eval(inputEq);
}
// change x to * for evaluator
else if (widget == 'x') {
screen.innerHTML += '*';
}
//clear the text inside the screen
else if (widget == 'C') {
screen.innerHTML = "";
} else {
screen.innerHTML += widget;
}
}
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript" src="main.js"></script>
<link href="css.css" type="text/css" rel="stylesheet" />
</head>
<body>
<div id="calculator">
<!-- Screen and clear button -->
<div class="top">
<span class="clear">C</span>
<div class="screen"></div>
</div>
<div class="buttons">
<!-- number operators and other buttons -->
<span>7</span>
<span>8</span>
<span>9</span>
<span class="operator">DEL</span>
<span>4</span>
<span>5</span>
<span>6</span>
<span class="operator">/</span>
<span>1</span>
<span>2</span>
<span>3</span>
<span class="operator">x</span>
<span>+/-</span>
<span>0</span>
<span>.</span>
<span class="operator">-</span>
<span>(</span>
<span>)</span>
<span class="eval">=</span>
<span class="operator">+</span>
</div>
</div>
</body>
</html>
出于某种原因,单击时没有跨度值显示在屏幕部分。我不确定发生了什么。我尝试了各种技术来将更新功能分配给单击按钮,但似乎没有任何效果。如果你们注意到一些我没有注意到的事情,请告诉我。
这是CSS
* {
margin: 0;
padding: 0;
box-sizing: border-box;
font: bold 14px Verdana, Geneva, sans-serif;
}
html {
height: 100%;
background: black;
background-size: cover;
}
#calculator {
width: 325px;
height: auto;
margin: 100px auto;
padding: 20px 20px 9px;
background: #b6ffad;
border-radius: 20px;
box-shadow: 0px 4px #94ce8c, 0px 10px 15px rgba(0, 0, 0, 0.2);
}
.top span.clear {
float: left;
}
.top .screen {
height: 40px;
width: 212px;
float: right;
padding: 0 10px;
background: rgba(0, 0, 0, 0.2);
border-radius: 20px;
box-shadow: inset 0px 4px rgba(0, 0, 0, 0.2);
font-size: 17px;
line-height: 40px;
color: white;
text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2);
text-align: right;
letter-spacing: 1px;
}
.buttons, .top {overflow: hidden;}
.buttons span, .top span.clear {
float: left;
position: relative;
top: 0;
cursor: pointer;
width: 66px;
height: 36px;
background: white;
border-radius: 20px;
box-shadow: 0px 4px rgba(0, 0, 0, 0.2);
margin: 0 7px 11px 0;
color: #565656;
line-height: 36px;
text-align: center;
user-select: none;
transition: all 0.2s ease;
}
.buttons span.operator {
background: #afafaf;
box-shadow: 0px 4px #878787;
margin-right: 0;
color: white;
}
.buttons span.eval {
background: #4c4c4c;
box-shadow: 0px 4px #333333;
color: white;
}
.top span.clear {
background: #ff9fa8;
box-shadow: 0px 4px #ff7c87;
color: white;
}
.buttons span:hover {
background: #82d179;
box-shadow: 0px 4px #64a05d;
color: white;
}
.buttons span.eval:hover {
background: #e2e2e2;
box-shadow: 0px 4px #bababa;
color: black;
}
.top span.clear:hover {
background: #f68991;
box-shadow: 0px 4px #d3545d;
color: white;
}
.buttons span:active {
box-shadow: 0px 0px #ffffff;
top: 4px;
}
.buttons span.eval:active {
box-shadow: 0px 0px #ffffff;
top: 4px;
}
.top span.clear:active {
top: 4px;
box-shadow: 0px 0px #ffffff;
}
最佳答案
以这种方式分配一个 onclick 处理程序不会自动传递被点击的元素作为处理程序的上下文。因此你在里面引用了这个update
引用window
而不是 <span>
元素。
要实现您想要的效果,请按如下方式修改您的 .js 文件:
for (var count = 0; count < listener.length; count++) {
listener[count].onclick = function(event){
// ^---include the event param here
update(event);
// ^---- pass the reference to your update function
};
}
// v-----define an event parameter 'e' in your update function
function update(e) {
// Your new widget variable will be:
var widget = e.target.innerHTML;
//...include the rest of your code as is
// apart from:
else if (widget == '=') {
//screen.innerHTML = eval(inputEq);
// ^---- inputEq not defined anywhere
// change to:
screen.innerHTML = eval(screen.innerHTML);
}
}
关于javascript - span 类元素中没有显示任何值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43023993/
我有一个模式来匹配类似的东西 ... 1036 ... 但是我不想匹配 1036 因为会抓 1036 但无论如何我不想捕获双倍跨度,因为我不需要这些数据。我需要跨度和行尾之间的数据。 我在跨度的末尾尝
如何使用正则表达式来匹配该字符串: regularexpression . 如何交换第一个跨度的内容和第二个跨度的内容。 我认为可以使用jquery源码。 最佳答案 请务必阅读 RegEx match
我正在测试一个指令,该指令会在 200 个字符后 chop 文本。它改变了这一点: 对此: long text long text long text long text long
我有代码将这个字符串解析成一个字符数组: var textArray = Regex.Replace(text, @"]*|/)?>", String.Empty).Trim().ToCharA
我正在尝试使用 BeautifulSoup 提取包含在 id="titleDescription"范围内的字符串。 Customer Choice Award Winner
Hello
拆分为 Hello如何分割Hello至 Hello使用javascript var text = "Hello"; 记住:我不知道什么包含 , 我不知道 有没有属性 我找到了答案! var patt=/^(.*)$/i
我有一个数组列表 ArrayList al = new ArrayList(); al.add("tree good has"); al.add("ok go by"); al.add
我有一个使用 span 的 html 文件关键字以两种不同的方式。 第一个在第二个定义中 button.groovyButton span这里: button.groovyButton { b
仍在尝试让新站点的导航控件按照我想要的方式工作。 我将我的问题简化为这段代码: Test span { display: inline-block; heigh
This is 城市。它因 而闻名。
”我是编码新手 在下面的 pgm 中,任何人都可以帮我找出为什么 ng-bind 不起作用吗? 提前致谢。 Angular js Welocme!Please enter valu
我必须在下面的 html 代码中提取文本内容以进行 python 网络抓取,问题是类参数,所有三个变量都具有相同的类参数,所以我尝试使用 arial-label,但它不起作用。 2, 3 Proper
如何填充一组 带有一个带有循环的单词数组? 如果数组包含[ "one", "two", "three" ]并被称为“wordarray” 然后我想填充跨度,使其看起来像 one two
如果我们有 div 并且没有跨度,即一个跨度中的跨度,并且每个跨度都有一种颜色样式,如何使用 css 或 jquery 覆盖特定样式[颜色]..。请帮助我 最佳答案 你的意思是这样的吗? red bl
我以为下面的选择器只会匹配example b。有人可以向我解释一下 CSS 路径的工作原理吗? body div span a{ background:#000; color:#fff
我正在尝试获取内可用的文本元素。我已经使用innerHTML来检索内部文本,但很少元素内部文本放置在 内元素。 在检索文本值时,将其获取为 sample text作为输出字符串。谁能帮我删除 在输出
我应该加上“n” (显示“n”flaticon-icons)到一个div(我的页面是.php) 这是 div 这是 div_icon CSS 类 @media (max-width: 600px
无法获取“表格”中的跨度文本,谢谢! from bs4 import BeautifulSoup import urllib2 url1 = "url" content1 = urllib2.urlo
这个问题在这里已经有了答案: My inline-block elements are not lining up properly (5 个答案) 关闭 8 年前。 HTML $ 400 这会在同
我正在尽力在图像中插入 span 标签标题。 两者都在段落和 span 标签内。 如何让 lorem ipsum 文本作为标题出现在图像的底部?? Lorem ipsum dolor
我有以下 HTML 文件。 "| Testing" 我要打印 "| Testing" , 而不是打印这个打印 "| Testing" .所有这
我是一名优秀的程序员,十分优秀!