如何利用js實(shí)時(shí)監(jiān)聽input輸入框值的變化
實(shí)習(xí)日記之通過調(diào)用common chemistry的api接口實(shí)現(xiàn)輸入keyword查找cas號(hào)和mw。做了一個(gè)簡單的html網(wǎng)頁,用到了ajax技術(shù)。比較簡單,適合剛?cè)腴T的寶學(xué)習(xí)參考。代碼如下:

<!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>Document</title>
<script type="application/javascript">
function onInputChange(event){
console.log(event.target.value);
if(event.target.value == ''){
document.getElementById("cas").innerText = '';
document.getElementById("mw").innerText = '';
}
}
function loadCAS() {
// document.getElementById("cas").innerText = '';
// document.getElementById("mw").innerText = '';
var flag = 1;
var searchurl = 'https://commonchemistry.cas.org/api/search?q='; // 獲取 JSON 數(shù)據(jù)的鏈接
var request;
if (window.XMLHttpRequest) {
request = new XMLHttpRequest(); //發(fā)送 Ajax 請求,適用于 Chrome, mozilla 等瀏覽器
} else if (window.ActiveXObject) {
request = new ActiveXObject("Microsoft.XMLHTTP"); // 發(fā)送 Ajax 請求,適用于 IE 瀏覽器
}
var keyword = document.getElementById("keyword").value;
searchurl += encodeURIComponent(keyword);
request.open("GET", searchurl, false);
request.onreadystatechange = function() {
if (request.readyState == 4 && request.status == 200) {
var response = request.responseText;
console.log(JSON.parse(response));
if(JSON.parse(response).count.toString() =='0'){
document.getElementById("cas").innerText = '暫無數(shù)據(jù)';
flag = 0;
}
else{
document.getElementById("cas").innerHTML = JSON.parse(response).results[0].rn;
}
}else if(request.readyState == 4 && request.status == 404){
}
}
request.send();
if(flag == 1){
loadMW();
}
}
function loadMW(){
var detailurl = 'https://commonchemistry.cas.org/api/detail?cas_rn='; // 獲取 JSON 數(shù)據(jù)的鏈接
var request;
if (window.XMLHttpRequest) {
request = new XMLHttpRequest(); //發(fā)送 Ajax 請求,適用于 Chrome, mozilla 等瀏覽器
} else if (window.ActiveXObject) {
request = new ActiveXObject("Microsoft.XMLHTTP"); // 發(fā)送 Ajax 請求,適用于 IE 瀏覽器
}
var cas = document.getElementById("cas").innerText.toString();
console.log('loadMW-cas:'+cas);
detailurl += encodeURIComponent(cas);
request.open("GET", detailurl, false);
request.onreadystatechange = function() {
if (request.readyState == 4 && request.status == 200) {
var response = request.responseText;
console.log(JSON.parse(response));
document.getElementById("mw").innerHTML = JSON.parse(response).molecularMass;
}else if(request.readyState == 4 && request.status == 404){
}
}
request.send();
}
</script>
</head>
<body>
<label for="keyword"> Keyword: </label>
<input type="text" id="keyword" name="keyword" oninput="onInputChange(event)" >
<br>
<div>
CAS: <span id="cas"></span>
</div>
<div>
MW: <text id="mw"></text>
</div>
<button type="button" onclick="loadCAS()">點(diǎn)擊加載</button>
</body>
</html>過程中遇到的問題:當(dāng)我清空keyword值后,上一次搜索的cas和mw依然存在。
方案一:js實(shí)時(shí)監(jiān)聽input輸入框值的變化,需要用到input監(jiān)聽事件:
<input type="text" id="keyword" name="keyword" oninput="onInputChange(event)" >
調(diào)用對應(yīng)的js監(jiān)聽函數(shù):
function onInputChange(event){
console.log(event.target.value);
if(event.target.value == ''){
document.getElementById("cas").innerText = '';
document.getElementById("mw").innerText = '';
}
}剛開始在這里踩了個(gè)坑,我以為event.target.value的值是null,所以條件寫成了if(event.target.value == null),數(shù)據(jù)一直無法清空。后來我改成了空字符串if(event.target.value == '')就對了。
方案二:在點(diǎn)擊加載按鈕的時(shí)候,先將元素內(nèi)容清空再進(jìn)行ajax請求,直接在點(diǎn)擊事件觸發(fā)的方法里清空數(shù)據(jù)即可。
//點(diǎn)擊事件
function loadCAS() {
document.getElementById("cas").innerText = '';
document.getElementById("mw").innerText = '';
......
}附j(luò)Query用法:
$("#input1").bind("input propertychange",function(event){
console.log($("#input1").val())
});總結(jié)
到此這篇關(guān)于如何利用js實(shí)時(shí)監(jiān)聽input輸入框值變化的文章就介紹到這了,更多相關(guān)js實(shí)時(shí)監(jiān)聽input輸入框值內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js尾調(diào)用優(yōu)化的實(shí)現(xiàn)
這篇文章主要介紹了js尾調(diào)用優(yōu)化的實(shí)現(xiàn),尾調(diào)用(Tail Call)是函數(shù)式編程的一個(gè)重要概念,本文介紹它的含義和用法。感興趣的可以了解一下2019-05-05
Taro UI框架開發(fā)小程序?qū)崿F(xiàn)左滑喜歡右滑不喜歡效果的示例代碼
這篇文章主要介紹了Taro UI開發(fā)小程序?qū)崿F(xiàn)左滑喜歡右滑不喜歡效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
微信小程序日期增加時(shí)間完成訂單失效倒計(jì)時(shí)效果
這篇文章主要介紹了微信小程序日期增加時(shí)間完成訂單失效倒計(jì)時(shí)效果,在我們?nèi)粘Y徫镞^程中經(jīng)常會(huì)遇到這樣的功能,本文通過示例代碼給大家詳細(xì)講解,需要的朋友參考下吧2024-04-04
js實(shí)現(xiàn)接收表單的值并將值拼在表單action后面的方法
這篇文章主要介紹了js實(shí)現(xiàn)接收表單的值并將值拼在表單action后面的方法,涉及JavaScript動(dòng)態(tài)操作字符串及表單元素的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
基于javascript代碼實(shí)現(xiàn)通過點(diǎn)擊圖片顯示原圖片
這篇文章主要介紹了基于javascript代碼實(shí)現(xiàn)通過點(diǎn)擊圖片顯示原圖片的相關(guān)資料,需要的朋友可以參考下2015-11-11
JavaScript實(shí)現(xiàn)仿網(wǎng)易通行證表單驗(yàn)證
這篇文章主要介紹了JavaScript實(shí)現(xiàn)仿網(wǎng)易通行證表單驗(yàn)證,十分的實(shí)用,有需要的小伙伴可以參考下。2015-05-05
原生js實(shí)現(xiàn)類似彈窗抖動(dòng)效果
這篇文章主要介紹了原生js實(shí)現(xiàn)類似彈窗抖動(dòng)效果的相關(guān)資料,推薦給大家,需要的朋友可以參考下2015-04-04

