跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
JavaScriptAI大前端

HTML5 结合 AI 实现智能前端交互与渲染

HTML5 与 AI 技术融合重塑前端开发边界。文章解析 HTML5 核心特性与前端 AI 推理机制,通过 Canvas 绘图、智能表单及天气应用案例,展示 AI 接口调用封装与数据交互流程。内容涵盖性能优化策略、渐进增强最佳实践及常见问题解答,帮助开发者掌握智能化前端工程化能力,提升用户体验与开发效率。

RedisGeek发布于 2026/4/10更新于 2026/6/620 浏览

引言

在前端技术快速发展的今天,HTML5 与 AI 技术的深度融合正在重新定义前端开发的边界和可能性。

1.1 背景与意义

核心认知:HTML5 与 AI 的结合,让前端开发从"静态展示"进化为"智能交互"。这种变革不仅提升了用户体验,更开辟了前端开发的新范式。

从 2020 年 TensorFlow.js 的成熟,到如今 AI 辅助开发工具的普及,前端开发正在经历一场智能化革命。

1.2 本章结构概览

为了帮助读者系统性地掌握本章内容,我将从以下几个维度展开:

概念解析 → 技术原理 → 实现方法 → 实践案例 → 最佳实践 → 总结展望

核心概念

2.1 基本定义

让我们首先明确几个核心概念:

概念一:HTML5 核心特性

HTML5 是 HTML 的最新版本,引入了大量新特性:

特性说明应用场景
语义化标签header、nav、article 等SEO 优化、结构清晰
Canvas2D/3D 绘图能力图表、游戏、图像处理
音视频原生多媒体支持播放器、直播、会议
本地存储localStorage、IndexedDB离线应用、数据持久化
Web API地理位置、拖拽、通知增强交互体验

概念二:AI 在前端的应用

AI 技术在前端的主要应用包括:

  • 智能内容生成:自动生成页面内容
  • 智能交互:语音识别、手势识别
  • 数据处理:文本分析、图像识别
  • 用户体验优化:个性化推荐、智能搜索

2.2 关键术语解释

注意:以下术语是理解本章内容的基础,请务必掌握。

术语 1:前端 AI 推理

前端 AI 推理是指在浏览器端直接运行 AI 模型,无需服务器参与。这种方式具有低延迟、保护隐私的优势。

术语 2:AI 辅助开发

AI 辅助开发是指利用 AI 工具提升开发效率,包括代码补全、自动生成、智能调试等。

2.3 技术架构概览

架构理解:

┌─────────────────────────────────────────┐
│ 用户界面层 (UI) │
│ HTML5 + CSS3 + JavaScript │
├─────────────────────────────────────────┤
│ AI 能力层 (AI) │
│ TensorFlow.js / ONNX.js / 自定义模型 │
├─────────────────────────────────────────┤
│ 数据处理层 (Data) │
│ Fetch API / WebSocket / IndexedDB │
├─────────────────────────────────────────┤
│ 服务接口层 (API) │
│ RESTful API / GraphQL / gRPC │
└─────────────────────────────────────────┘

技术原理

3.1 核心技术原理

本节将深入探讨技术实现细节。

HTML5 结合 AI 实现智能场景渲染的核心实现涉及以下关键技术:

技术一:HTML5 Canvas 与 AI 结合

目录

  1. 引言
  2. 1.1 背景与意义
  3. 1.2 本章结构概览
  4. 核心概念
  5. 2.1 基本定义
  6. 2.2 关键术语解释
  7. 2.3 技术架构概览
  8. 技术原理
  9. 3.1 核心技术原理
  10. 3.2 数据交互机制
  11. 3.3 性能优化策略
  12. 实践应用
  13. 4.1 应用场景分析
  14. 4.2 实施步骤详解
  15. HTML5+AI 技术选型清单
  16. 前端框架
  17. AI 能力
  18. 数据处理
  19. 4.3 最佳实践分享
  20. 案例分析
  21. 5.1 成功案例
  22. 5.2 失败教训
  23. 常见问题
  24. 6.1 技术问题
  25. 6.2 应用问题
  26. 发展趋势
  27. 7.1 技术趋势
  28. 7.2 应用趋势
  29. 7.3 职业发展
  30. 总结
  31. 8.1 核心要点回顾
  32. 8.2 学习建议
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • 家庭 AI 助手(三):QQ 机器人接入 OpenClaw
  • KoboldAI 安装与配置指南
  • Docker Compose 安装 OpenClaw 并接入飞书应用
  • Transformer 入门到精通:核心架构与算法详解
  • RAGFlow 实现 GraphRAG 知识库多模态问答与 AI 编排流体验
  • OpenClaw 开源 AI 助手安装及飞书接入实战
  • MySQL 与 Navicat Windows 安装配置实战指南
  • C++中%取余运算符与模运算的区别
  • Docker 部署 OpenClaw 常见问题:Web UI 访问、飞书配对及模型配置
  • 基于 browser-tools-mcp 的 MCP 插件配置实战
  • WebAssembly Studio 在线开发环境完全指南
  • HTML 基础语法与简单网页制作示例
  • 基于 WebTop 与 Tailscale 的云端 OpenClaw 真实浏览器部署方案
  • 深入理解与使用 Cookie:Web 开发关键机制
  • Python 爬虫接单经验分享与项目注意事项
  • Python 基础教程:从环境搭建到核心语法详解
  • 修复 Microsoft Visual C++ 2022 X86 Minimum Runtime 安装错误
  • Python 批量给图片添加文字或图片水印实战
  • GLM-4-9B 开源发布:支持 26 种语言与 128K 上下文,性能优于 Llama-3-8B
  • 8 个实用 jQuery 技巧

相关免费在线工具

  • RSA密钥对生成器

    生成新的随机RSA私钥和公钥pem证书。 在线工具,RSA密钥对生成器在线工具,online

  • Mermaid 预览与可视化编辑

    基于 Mermaid.js 实时预览流程图、时序图等图表,支持源码编辑与即时渲染。 在线工具,Mermaid 预览与可视化编辑在线工具,online

  • 随机西班牙地址生成器

    随机生成西班牙地址(支持马德里、加泰罗尼亚、安达卢西亚、瓦伦西亚筛选),支持数量快捷选择、显示全部与下载。 在线工具,随机西班牙地址生成器在线工具,online

  • Keycode 信息

    查找任何按下的键的javascript键代码、代码、位置和修饰符。 在线工具,Keycode 信息在线工具,online

  • Escape 与 Native 编解码

    JavaScript 字符串转义/反转义;Java 风格 \uXXXX(Native2Ascii)编码与解码。 在线工具,Escape 与 Native 编解码在线工具,online

  • JavaScript / HTML 格式化

    使用 Prettier 在浏览器内格式化 JavaScript 或 HTML 片段。 在线工具,JavaScript / HTML 格式化在线工具,online

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>HTML5 Canvas + AI 智能绘图</title>
    <style>
        .canvas-container { display: flex; flex-direction: column; align-items: center; padding: 20px; }
        #drawCanvas { border: 2px solid #333; background: #fff; cursor: crosshair; }
        .controls { margin-top: 15px; display: flex; gap: 10px; }
        button { padding: 10px 20px; font-size: 16px; cursor: pointer; }
    </style>
</head>
<body>
    <div class="canvas-container">
        <h2>AI 智能绘图识别</h2>
        <canvas id="drawCanvas" width="400" height="400"></canvas>
        <div class="controls">
            <button onclick="clearCanvas()">清除</button>
            <button onclick="recognizeDrawing()">AI 识别</button>
        </div>
        <div id="result"></div>
    </div>
    <script>
        const canvas = document.getElementById('drawCanvas');
        const ctx = canvas.getContext('2d');
        let isDrawing = false;

        canvas.addEventListener('mousedown', startDrawing);
        canvas.addEventListener('mousemove', draw);
        canvas.addEventListener('mouseup', stopDrawing);
        canvas.addEventListener('mouseout', stopDrawing);

        function startDrawing(e) {
            isDrawing = true;
            ctx.beginPath();
            ctx.moveTo(e.clientX - canvas.offsetLeft, e.clientY - canvas.offsetTop);
        }

        function draw(e) {
            if (!isDrawing) return;
            ctx.lineTo(e.clientX - canvas.offsetLeft, e.clientY - canvas.offsetTop);
            ctx.strokeStyle = '#000';
            ctx.lineWidth = 3;
            ctx.stroke();
        }

        function stopDrawing() { isDrawing = false; }

        function clearCanvas() {
            ctx.(, , canvas., canvas.);
            .(). = ;
        }

          () {
             imageData = canvas.();
             {
                 response =  (, {
                    : ,
                    : { :  },
                    : .({ : imageData })
                });
                 result =  response.();
                .(). =  + result. +  +  + (result. * ).() + ;
            }  (error) {
                .(, error);
                .(). = ;
            }
        }
    </script>
</body>
</html>

技术二:AI 接口调用封装

// AI 接口调用封装类
class AIService {
    constructor(baseUrl, apiKey) {
        this.baseUrl = baseUrl;
        this.apiKey = apiKey;
    }

    // 文本生成
    async generateText(prompt, options = {}) {
        const response = await fetch(`${this.baseUrl}/generate`, {
            method: 'POST',
            headers: { 'Content-Type': 'application/json', 'Authorization': `Bearer ${this.apiKey}` },
            body: JSON.stringify({ prompt: prompt, max_tokens: options.maxTokens || 500, temperature: options.temperature || 0.7 })
        });
        if (!response.ok) throw new Error(`API 请求失败:${response.status}`);
        return await response.json();
    }

    // 图像识别
    async recognizeImage(imageData) {
        const response = await fetch(`${this.baseUrl}/vision`, {
            method: 'POST',
            headers: { 'Content-Type': 'application/json', 'Authorization': `Bearer ${this.apiKey}` },
            body: JSON.stringify({ image: imageData })
        });
        return await response.json();
    }

    // 语音识别
    async transcribeAudio(audioBlob) {
        const formData = new FormData();
        formData.append('audio', audioBlob);
        const response = await fetch(`${this.baseUrl}/speech`, {
            method: 'POST',
            headers: { 'Authorization': `Bearer ${this.apiKey}` },
            body: formData
        });
        return await response.json();
    }
}

// 使用示例
const aiService = new AIService('https://api.example.com', 'your-api-key');
aiService.generateText('请生成一段产品介绍').then(result => console.log(result.text)).catch(error => console.error(error));

3.2 数据交互机制

数据流设计:

流程一:用户输入 → AI 处理 → 页面渲染

// 完整的数据交互流程
class HTML5AIApp {
    constructor() {
        this.aiService = new AIService('https://api.example.com', 'key');
        this.initEventListeners();
    }

    initEventListeners() {
        document.getElementById('userInput').addEventListener('submit', (e) => this.handleUserInput(e));
    }

    async handleUserInput(event) {
        event.preventDefault();
        const input = document.getElementById('inputField').value;
        this.showLoading();
        try {
            const result = await this.aiService.generateText(input);
            this.renderResult(result);
        } catch (error) {
            this.showError(error.message);
        } finally {
            this.hideLoading();
        }
    }

    renderResult(result) {
        const container = document.getElementById('resultContainer');
        const article = document.createElement('article');
        article.className = 'ai-result';
        article.innerHTML = `
            <header>
                <h3>AI 生成内容</h3>
                <time datetime="${new Date().toISOString()}">${new Date().toLocaleString()}</time>
            </header>
            <section>${result.text}</section>
            <footer><small>由 AI 生成,仅供参考</small></footer>
        `;
        container.appendChild(article);
    }

    showLoading() { document.getElementById('loading').style.display = 'block'; }
    hideLoading() { document.getElementById('loading').style.display = 'none'; }
    showError(message) {
        const errorDiv = document.createElement('div');
        errorDiv.className = 'error-message';
        errorDiv.textContent = message;
        document.getElementById('resultContainer').appendChild(errorDiv);
    }
}

3.3 性能优化策略

优化技巧:

优化方向具体方法效果
资源加载懒加载、预加载减少 50% 加载时间
模型优化模型量化、剪枝减少 70% 模型大小
缓存策略Service Worker离线可用
渲染优化虚拟列表、防抖提升流畅度

实践应用

4.1 应用场景分析

核心场景:以下是 HTML5 结合 AI 实现智能场景渲染的主要应用场景。

场景一:智能表单

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>AI 智能表单</title>
</head>
<body>
    <form id="smartForm">
        <div class="form-group">
            <label for="email">邮箱</label>
            <input type="email" id="email" name="email" placeholder="请输入邮箱" required>
            <span class="validation-message"></span>
        </div>
        <div class="form-group">
            <label for="phone">手机号</label>
            <input type="tel" id="phone" name="phone" placeholder="请输入手机号" required>
            <span class="validation-message"></span>
        </div>
        <div class="form-group">
            <label for="address">地址</label>
            <input type="text" id="address" name="address" placeholder="开始输入地址..." autocomplete="off">
            <div class="suggestions"></div>
        </div>
        <button type="submit">提交</button>
    </form>
    <script>
        class SmartForm {
            constructor(formId) {
                this.form = document.getElementById(formId);
                this.initAIValidation();
                this.initAddressAutocomplete();
            }

            initAIValidation() {
                const inputs = this.form.querySelectorAll('input');
                inputs.forEach(input => {
                    input.addEventListener('blur', async () => {
                        await this.validateWithAI(input);
                    });
                });
            }

            async validateWithAI(input) {
                const value = input.value;
                if (!value) return;
                const messageSpan = input.parentElement.querySelector('.validation-message');
                try {
                    const response = await fetch('/api/validate', {
                        method: 'POST',
                        headers: { 'Content-Type':  },
                        : .({ : input., : value })
                    });
                     result =  response.();
                     (result.) {
                        messageSpan. = ;
                        messageSpan. = ;
                    }  {
                        messageSpan. = result. || ;
                        messageSpan. = ;
                    }
                }  (error) {
                    .(, error);
                }
            }

            () {
                 addressInput = ..();
                 suggestionsDiv = addressInput..();
                 debounceTimer;
                addressInput.(,  {
                    (debounceTimer);
                    debounceTimer = ( () => {
                         query = e..;
                         (query. < ) { suggestionsDiv. = ; ; }
                         {
                             response =  ();
                             suggestions =  response.();
                            .(suggestions, suggestionsDiv, addressInput);
                        }  (error) {
                            .(, error);
                        }
                    }, );
                });
            }

            () {
                container. = suggestions.( ).();
                . =  {
                    input. = address;
                    container. = ;
                };
            }
        }
         ();
    </script>
</body>
</html>

场景二:智能内容生成

应用领域具体用途AI 能力
文章生成根据主题生成文章NLP 生成
图片生成根据描述生成图片图像生成
代码生成根据需求生成代码代码生成
数据分析自动分析并可视化数据分析

4.2 实施步骤详解

操作指南:以下是完整的实施步骤。

步骤一:需求分析

在开始之前,需要明确:

  1. 目标用户是谁?
  2. 核心功能是什么?
  3. 需要哪些 AI 能力?
  4. 技术约束有哪些?

步骤二:技术选型

## HTML5+AI 技术选型清单
### 前端框架
- [ ] Vue.js - 渐进式框架
- [ ] React - 组件化框架
- [ ] 原生 JavaScript - 轻量级方案
### AI 能力
- [ ] TensorFlow.js - 前端 ML 框架
- [ ] ONNX.js - 模型推理
- [ ] API 调用 - 云端 AI 服务
### 数据处理
- [ ] Fetch API - 网络请求
- [ ] IndexedDB - 本地存储
- [ ] WebSocket - 实时通信

步骤三:开发实现

开发阶段的关键任务:

任务描述时间
页面结构HTML5 语义化标签1 天
样式设计CSS3 响应式布局2 天
交互逻辑JavaScript 事件处理2 天
AI 集成接口对接与优化3 天
测试调试功能与性能测试2 天

4.3 最佳实践分享

经验总结:

最佳实践一:渐进增强

  1. 先实现基础功能
  2. 逐步添加 AI 能力
  3. 优雅降级处理
  4. 持续优化体验

最佳实践二:性能优先

  • 模型按需加载
  • 请求合并压缩
  • 结果缓存复用
  • 渲染优化加速

案例分析

5.1 成功案例

案例一:智能天气展示页面

背景介绍

某天气应用需要提升用户体验,决定引入 AI 能力实现智能推荐和交互。

解决方案

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>AI 智能天气</title>
    <style>
        .weather-card { background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); border-radius: 20px; padding: 30px; color: white; max-width: 400px; margin: 20px auto; }
        .weather-icon { font-size: 80px; text-align: center; }
        .temperature { font-size: 60px; text-align: center; font-weight: bold; }
        .ai-suggestion { background: rgba(255,255,255,0.2); border-radius: 10px; padding: 15px; margin-top: 20px; }
        .outfit-recommendation { display: flex; gap: 10px; margin-top: 15px; }
        .outfit-item { background: rgba(255,255,255,0.3); padding: 10px; border-radius: 8px; text-align: center; }
    </style>
</head>
<body>
    <div class="weather-card">
        <div class="weather-icon" id="weatherIcon">☀️</div>
        <div class="temperature" id="temperature">25°C</div>
        <div class="location" id="location">北京市</div>
        <div class="ai-suggestion">
            <h4>🤖 AI 智能建议</h4>
            <p id="aiAdvice">今天天气晴朗,适合户外活动。建议穿着轻薄透气的衣物。</p>
            <div class="outfit-recommendation">
                <div class="outfit-item">👕<br>T 恤</div>
                <div class="outfit-item">👖<br>休闲裤</div>
                <div class="outfit-item">👟<br>运动鞋</div>
            </div>
        </div>
    </div>
    <script>
        class AIWeatherApp {
            constructor() { this.loadWeather(); }
            async loadWeather() {
                try {
                    const position = await this.getLocation();
                    const weather = await this.fetchWeather(position);
                    const advice = await this.generateAIAdvice(weather);
                    this.render(weather, advice);
                } catch (error) { console.error('加载失败:', error); }
            }
            getLocation() {
                return new Promise((resolve, reject) => {
                    navigator.geolocation.getCurrentPosition(pos => resolve({ lat: pos.coords.latitude, lng: pos.coords.longitude }), err => reject(err));
                });
            }
            async fetchWeather(position) {
                 response =  ();
                  response.();
            }
             () {
                 response =  (, {
                    : ,
                    : { :  },
                    : .({ weather })
                });
                  response.();
            }
            () {
                .(). = weather.;
                .(). = ;
                .(). = weather.;
                .(). = advice.;
            }
        }
         ();
    </script>
</body>
</html>

实施效果

指标实施前实施后提升幅度
用户停留时间30 秒2 分钟300%
用户满意度70%92%31%
日活跃用户1 万3 万200%

5.2 失败教训

案例二:过度依赖 AI 导致性能问题

问题分析

某项目过度使用 AI 能力,导致:

  1. 页面加载过慢
  2. 用户等待时间长
  3. 资源消耗过大
  4. 用户体验下降

经验教训

警示:

  • 合理评估 AI 必要性
  • 优化模型大小和加载
  • 实现渐进式体验
  • 设置合理的超时时间

常见问题

6.1 技术问题

Q1:如何选择前端 AI 方案?

建议:

方案适用场景优点缺点
TensorFlow.js复杂模型推理功能强大体积大
ONNX.js跨平台模型兼容性好学习曲线
API 调用简单场景快速集成依赖网络

Q2:如何处理 AI 请求失败?

// 完善的错误处理机制
async function safeAICall(apiCall, fallback) {
    try {
        const result = await Promise.race([apiCall(), new Promise((_, reject) => setTimeout(() => reject(new Error('请求超时')), 5000))]);
        return result;
    } catch (error) {
        console.error('AI 调用失败:', error);
        if (fallback) return await fallback();
        return { success: false, error: error.message };
    }
}

// 使用示例
const result = await safeAICall(() => aiService.generateText('你好'), () => ({ text: '抱歉,AI 服务暂时不可用' }));

6.2 应用问题

Q3:如何优化 AI 页面性能?

优化策略:

  1. 模型懒加载
  2. 请求缓存
  3. 结果预计算
  4. Web Worker 处理

Q4:如何保证 AI 内容安全?

安全要点:

  • 输入内容过滤
  • 输出内容审核
  • 敏感词过滤
  • 用户举报机制

发展趋势

7.1 技术趋势

发展方向:

趋势描述预计时间
端侧 AI浏览器本地运行大模型1-2 年
多模态文本、图像、语音统一处理2-3 年
AI 原生AI 成为前端核心能力3-5 年
智能化开发AI 辅助全流程开发已实现

7.2 应用趋势

核心判断:

未来 3-5 年,HTML5+AI 将在以下领域产生深远影响:

  1. 企业应用:智能办公、数据分析
  2. 电商平台:智能推荐、虚拟试穿
  3. 在线教育:个性化学习、智能辅导
  4. 娱乐内容:互动游戏、内容生成

7.3 职业发展

职业建议:

对于想要进入这一领域的读者,建议:

阶段学习重点时间投入
入门期HTML5 基础、AI 概念1-2 个月
进阶期AI 接口调用、简单应用2-4 个月
专业期模型部署、性能优化4-8 个月
专家期架构设计、创新应用1 年以上

总结

8.1 核心要点回顾

本章核心内容:

  1. 概念理解:明确了 HTML5 结合 AI 实现智能前端交互的基本定义和核心概念
  2. 技术原理:深入探讨了实现方法和核心技术
  3. 实践应用:提供了详细的代码示例和最佳实践
  4. 案例分析:通过真实案例加深理解
  5. 问题解答:解答了常见的技术和应用问题
  6. 趋势展望:分析了未来发展方向

8.2 学习建议

给读者的建议:

  1. 理论与实践结合:在理解概念的基础上,动手实践
  2. 循序渐进:从简单功能开始,逐步深入
  3. 持续学习:技术发展迅速,保持学习热情
  4. 交流分享:加入社区,与同行交流
clearRect
0
0
width
height
document
getElementById
'result'
innerHTML
''
async
function
recognizeDrawing
const
toDataURL
'image/png'
try
const
await
fetch
'/api/recognize'
method
'POST'
headers
'Content-Type'
'application/json'
body
JSON
stringify
image
const
await
json
document
getElementById
'result'
innerHTML
'<h3>识别结果:'
label
'</h3>'
'<p>置信度:'
confidence
100
toFixed
2
'%</p>'
catch
console
error
'识别失败:'
document
getElementById
'result'
innerHTML
'<p>识别失败,请重试</p>'
'application/json'
body
JSON
stringify
field
name
value
const
await
json
if
valid
textContent
'✓ 格式正确'
className
'validation-message success'
else
textContent
suggestion
'格式有误'
className
'validation-message error'
catch
console
error
'验证失败:'
initAddressAutocomplete
const
this
form
querySelector
'#address'
const
parentElement
querySelector
'.suggestions'
let
addEventListener
'input'
(e) =>
clearTimeout
setTimeout
async
const
target
value
if
length
2
innerHTML
''
return
try
const
await
fetch
`/api/address/suggest?q=${query}`
const
await
json
this
renderSuggestions
catch
console
error
'获取建议失败:'
300
renderSuggestions
suggestions, container, input
innerHTML
map
s =>
`<div onclick="selectSuggestion('${s.address}')">${s.address}</div>`
join
''
window
selectSuggestion
(address) =>
value
innerHTML
''
new
SmartForm
'smartForm'
const
await
fetch
`/api/weather?lat=${position.lat}&lng=${position.lng}`
return
await
json
async
generateAIAdvice
weather
const
await
fetch
'/api/ai/advice'
method
'POST'
headers
'Content-Type'
'application/json'
body
JSON
stringify
return
await
json
render
weather, advice
document
getElementById
'weatherIcon'
textContent
icon
document
getElementById
'temperature'
textContent
`${weather.temp}°C`
document
getElementById
'location'
textContent
city
document
getElementById
'aiAdvice'
textContent
text
new
AIWeatherApp