关于web对话窗口使用总结

本文详细介绍了对话框的两种类型:模态对话框与非模态对话框的区别,并提供了创建模态对话框和非模态对话框的JavaScript方法,包括返回值、自由参数和外观定制。此外,还展示了如何在主调页和被调页之间传递数据,以及如何在模态对话框中更新和获取变量。

 一、对话框一般分为两种类型:模态类型(modal)与非模态类型(modeless)。所谓模态对话框,就是指除非采取有效的关闭手段,用户的鼠标焦点或者输入光标将一直停留在其上的对话框。非模态对话框则不会强制此种特性,用户可以在当前对话框以及其他窗口间进行切换。

二、原型

创建模态对话框:(会缓存最近一次页面的值,通过一些设置可绕过系统的判断)
vReturnValue = window.showModalDialog(sURL [, vFreeArgument] [, sOrnaments]);
创建非模态对话框:(不会)
vReturnValue = window.showModelessDialog(sURL [, vFreeArgument] [, sOrnaments]);

· VReturnValue:对于showModalDialog(),它表示被打开的对话框窗口设置的returnValue属性值。对于showModelessDialog(),它表示新窗口对象。 
· VFreeArgument:这个参数可用于传递某种类型的数据到打开的对话框,数据可以是一个数值、字符串、数组或者一个对象类型。在新窗口中引用这个数值时,可通过新创建window对象的dialogArguments 属性。 
· SOrnaments:用这个参数指定新窗口的外观。可选择的窗口属性有很多种,当有多种控制需求时,将相关内容用一个字符串连接起来,其间用分号隔开。以下是可选择的属性种类: 
o dialogHeight: sHeight 
o dialogLeft: sXpos 
o dialogTop: sYpos 
o dialogWidth: sWidth 
o center: ( yes | no | 1 | 0 | on | off ) 
o dialogHide: ( yes | no | 1 | 0 | on | off ) 
o edge: ( sunken | raised ) 
o help: ( yes | no | 1 | 0 | on | off ) 
o resizable: ( yes | no | 1 | 0 | on | off ) 
o scroll: ( yes | no | 1 | 0 | on | off ) 
o status: ( yes | no | 1 | 0 | on | off ) 

 

三、使用范例

主调页

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
    <title>模态窗口和非模态窗口</title>

    <script language="javascript">
    var sColor="yyyy";
    var sName="xmddl369";
    function showModalWindow(){
        window.showModalDialog('test2.html',window,'dialogWidth:400px;dialogHeight:400px');
    }
    function showModellessWindow(){
        window.showModelessDialog('test2.html',window,'dialogWidth:400px;dialogHeight:400px;edge:sunken');
    }
    function update() 
    { 
        oColor.innerText = sColor; 
    } 
    function test()
    {
        alert(123);
    }
    document.write("sColor="+sColor+"<br>");
    document.write("sName="+sName+"<br>");
    </script>

</head>
<body>
    <form>
    <input type="button" name="button" value="打开一个模态窗口" onclick="showModalWindow()">
    <input type="button" name="button" value="打开一个非模态窗口" onclick="showModellessWindow()">
    <br>
    <p>
        输入你最喜欢的颜色: <span id="oColor" style="color: red; font-size: 24">Yellow</span></p>
    </form>
</body>
</html>


被调页

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
    <title>New Document </title>

    <script language="javascript">
    function getInfoAndUpdate() {
        var callerWindowObj = dialogArguments; //得到文档的引用
        callerWindowObj.sColor = document.all("oEnterColor").value; 
        callerWindowObj.update(); 
    }
    function cancel() { 
        var callerWindowObj = dialogArguments; //获取父窗口句柄
        callerWindowObj.test();//调用父窗口方法
        alert(callerWindowObj.sName);//获取父窗口中的变量
        callerWindowObj.sColor = "Yellow"; //设置父窗口的变量
        callerWindowObj.update();  //调用父窗口方法
    } 
    </script>
</head>
<body>
    <form>
    输入你最喜欢的颜色:<input type="text" name="oEnterColor" id="oEnterColor"><br>
    <br>
    <input value="Apply" type="button" onclick="getInfoAndUpdate();">
    <input value="Ok" type="button" onclick="getInfoAndUpdate();window.close();">
    <input value="Cancel" type="button" onclick="cancel();window.close();">
    </form>
</body>
</html>

### 实现Spring Boot中的AI对话窗口 为了实现在Spring Boot中集成AI对话窗口的功能,可以采用WebSocket技术来建立实时通信连接。通过创建一个基于Spring Boot的应用程序并配置必要的依赖项,能够有效地支持前端与后端之间的双向数据流。 #### 添加WebSocket依赖 当利用Spring Initializr初始化一个新的Spring Boot项目时,应当加入`Spring Web`以及`Spring WebSocket`这两个模块作为项目的构建基础[^1]: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> ``` #### 配置WebSocket服务器 定义一个类用于配置WebSocket服务端点,并注册消息处理器以处理来自客户端的消息请求。下面是一个简单的例子说明如何设置这些组件: ```java @Configuration @EnableWebSocketMessageBroker public class WebSocketConfig implements WebSocketMessageBrokerConfigurer { @Override public void configureMessageBroker(MessageBrokerRegistry config) { config.enableSimpleBroker("/topic"); config.setApplicationDestinationPrefixes("/app"); } @Override public void registerStompEndpoints(StompEndpointRegistry registry) { registry.addEndpoint("/ws").withSockJS(); } } ``` 此段代码启用了STOMP协议的支持,并指定了前缀路径以便于区分应用级别的目的地和代理广播的目的地。 #### 创建控制器接收消息 编写一个控制器用来监听特定主题下的事件,并向订阅者发送响应信息。这里假设有一个名为`/chat`的主题供用户交流互动: ```java @Controller public class ChatController { private final SimpMessagingTemplate messagingTemplate; @Autowired public ChatController(SimpMessagingTemplate messagingTemplate){ this.messagingTemplate = messagingTemplate; } @MessageMapping("/send/message") public void sendMessage(@Payload String message, Principal user) throws Exception{ // 处理接收到的信息... // 将回复推送给所有已订阅的客户 messagingTemplate.convertAndSend("/topic/messages", "Echo: " + message); } } ``` 上述示例展示了怎样捕获由前端发出的数据包并通过预设好的频道转发给其他参与者。 #### 前端页面设计 对于前端部分,则可借助Vue.js框架配合Element UI库快速搭建美观易用的人机交互界面。具体来说,在HTML文件内引入相应的JavaScript资源之后,就可以按照官方文档指导完成UI控件的选择、布局调整等工作[^2]。 最后值得注意的是,实际开发过程中还需要考虑安全性措施(如身份验证)、错误恢复机制等方面的内容,从而确保整个系统的稳定性和可靠性。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值