web:js提示框、询问框、输入框的使用

简介

在JavaScript中,常见的对话框有三种:警告框(alert)、确认框(confirm)和提示框(prompt)。

  1. 警告框(alert):用于向用户显示一条消息,并只有一个"确定"按钮。

  2. 确认框(confirm):用于让用户确认某个操作,有"确定"和"取消"两个按钮,根据用户点击的不同,返回布尔值(确定返回true,取消返回false)。

  3. 提示框(prompt):用于提示用户输入一些文本,有"确定"和"取消"两个按钮,以及一个文本输入框。点击"确定"返回输入框中的文本,点击"取消"返回null。

在 JavaScript 中,常用的对话框有三种类型,它们都是浏览器内置的全局方法:

功能介绍

警告框 (Alert)

用于显示警告信息,只有​​确定​​按钮

javascript 复制代码
alert("这是一条警告信息");

确认框 (Confirm)

用于确认操作,有​​确定​ ​和​​取消​​按钮,返回布尔值

javascript 复制代码
const result = confirm("确定要删除吗?");

if(result) {
  // 用户点击了确定

} else {
  // 用户点击了取消

}

提示框 (Prompt)

用于用户输入,包含​​确定​ ​、​​取消​ ​和​​输入框​

javascript 复制代码
const name = prompt("请输入您的名字", "默认名字");

if(name !== null) {
  console.log(`您输入的名字是:${name}`);
} else {
  console.log("您取消了输入");
}

性能说明

类型 返回值 是否阻塞代码
alert() undefined
confirm() true(确定)/false(取消)
prompt() 字符串(确定)/null(取消)

注意事项:

  1. 这些对话框会​​阻塞​​页面操作,直到用户操作

  2. 样式由浏览器决定,无法自定义

  3. 现代前端开发更推荐使用自定义模态框(例如通过 HTML/CSS 实现)

  4. 移动端支持可能有限

替代方案(自定义对话框示例)

html 复制代码
<!-- HTML -->
<div id="myModal" class="modal">
  <div class="modal-content">
    <p id="message"></p>
    <input id="inputField" type="text">
    <button id="confirmBtn">确定</button>
    <button id="cancelBtn">取消</button>
  </div>
</div>

<script>
// JavaScript 控制逻辑
function showCustomPrompt(msg, callback) {
  const modal = document.getElementById('myModal');
  modal.style.display = 'block';
  
  document.getElementById('message').innerText = msg;
  
  document.getElementById('confirmBtn').onclick = () => {
    const val = document.getElementById('inputField').value;
    callback(val);
    modal.style.display = 'none';
  };
  
  document.getElementById('cancelBtn').onclick = () => {
    callback(null);
    modal.style.display = 'none';
  };
}
</script>
相关推荐
一 乐9 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
Boilermaker19929 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
MM_MS10 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
꧁Q༒ོγ꧂10 小时前
LaTeX 语法入门指南
开发语言·latex
njsgcs10 小时前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue
alonewolf_9910 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
古城小栈10 小时前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust
ghie909011 小时前
基于MATLAB的TLBO算法优化实现与改进
开发语言·算法·matlab
恋爱绝缘体111 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
wuk99811 小时前
VSC优化算法MATLAB实现
开发语言·算法·matlab