H5实践(1)- UI管理

2024-09-02 22:48
文章标签 实践 ui 管理 h5

本文主要是介绍H5实践(1)- UI管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在前面

本人并不是专业从事H5开发。

因此本系列做法,请辩证看待。

UI管理

要达到的目标:

  • 每个UI单独一个html文件,定义界面
  • 每个UI单独一个js文件,编写界面逻辑
  • UI变化,浏览器不要请求新URL(即浏览器要像APP那样切换界面)。

步骤1 - 定义主界面

<body onload="main()"><div id="stage"><div id="login_ui"></div><div id="lobby_ui"></div><div id="room_ui"></div></div>
</body>

如上,定义了3个DIV。分别动态加载 登录界面、大厅界面、房间界面。

步骤2 - 定义UI界面

<table align="center"><tr><td><label for="txtaccount">账 号:</label></td><td><input type="text" id="txtaccount" value="test" /></td></tr><tr><td><label for="txtpassword">密 码:</label></td><td><input type="password" id="txtpassword" value="123" /></td></tr>
</table>
<br />
<button id="btnlogin" type="button">点击登录</button>

如,login_ui.html文件为登录界面,内容是上述定义。

步骤3 - 加载UI界面

$('#login_ui').load('login_ui.html', function() {})

如,通过jquery库动态加载界面到DIV中。

步骤4 - 显示UI界面

$("#stage div").each(function() {$(this).hide()
})
$('#login_ui').show()

如,通过jquery库,先隐藏所有DIV,再显示登录界面。

以上。

总结

通过这种方法,可以让UI单独在一个文件中定义。

即,每个UI对应2个文件 :

  • xxx_ui.html

    负责定义UI界面

  • xxx_ui.js

    负责编写UI的具体逻辑

这样,使得JS UI编程,符合MVC设计模式。

这篇关于H5实践(1)- UI管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131287

相关文章

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

MySQL数据类型与表操作全指南( 从基础到高级实践)

《MySQL数据类型与表操作全指南(从基础到高级实践)》本文详解MySQL数据类型分类(数值、日期/时间、字符串)及表操作(创建、修改、维护),涵盖优化技巧如数据类型选择、备份、分区,强调规范设计与... 目录mysql数据类型详解数值类型日期时间类型字符串类型表操作全解析创建表修改表结构添加列修改列删除列

Python自定义异常的全面指南(入门到实践)

《Python自定义异常的全面指南(入门到实践)》想象你正在开发一个银行系统,用户转账时余额不足,如果直接抛出ValueError,调用方很难区分是金额格式错误还是余额不足,这正是Python自定义异... 目录引言:为什么需要自定义异常一、异常基础:先搞懂python的异常体系1.1 异常是什么?1.2

深入解析Java NIO在高并发场景下的性能优化实践指南

《深入解析JavaNIO在高并发场景下的性能优化实践指南》随着互联网业务不断演进,对高并发、低延时网络服务的需求日益增长,本文将深入解析JavaNIO在高并发场景下的性能优化方法,希望对大家有所帮助... 目录简介一、技术背景与应用场景二、核心原理深入分析2.1 Selector多路复用2.2 Buffer

Linux之UDP和TCP报头管理方式

《Linux之UDP和TCP报头管理方式》文章系统讲解了传输层协议UDP与TCP的核心区别:UDP无连接、不可靠,适合实时传输(如视频),通过端口号标识应用;TCP有连接、可靠,通过确认应答、序号、窗... 目录一、关于端口号1.1 端口号的理解1.2 端口号范围的划分1.3 认识知名端口号1.4 一个进程

SpringBoot结合Knife4j进行API分组授权管理配置详解

《SpringBoot结合Knife4j进行API分组授权管理配置详解》在现代的微服务架构中,API文档和授权管理是不可或缺的一部分,本文将介绍如何在SpringBoot应用中集成Knife4j,并进... 目录环境准备配置 Swagger配置 Swagger OpenAPI自定义 Swagger UI 底

SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南

《SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南》本文将基于开源项目springboot-easyexcel-batch进行解析与扩展,手把手教大家如何在SpringBo... 目录项目结构概览核心依赖百万级导出实战场景核心代码效果百万级导入实战场景监听器和Service(核心