百度系列产品学习
1.react-bmapgl封装逻辑
Map
分析react-bmapgl库中Map组件的封装流程,并以mermaid图展示。首先分析Map组件的核心实现,包括生命周期方法和子组件渲染逻辑。然后研究WrapperHOC和Component基类的封装模式,理解事件绑定和属性处理的通用逻辑。最后将分析结果整理为mermaid流程图,展示组件间的继承关系和交互流程。
模块 | 作用 | 特点 |
---|---|---|
Component | 基类封装 | 提供统一状态管理、实例引用、事件控制 |
WrapperHOC | 高阶组件 | 抽象事件绑定逻辑,复用性高 |
Map | 主入口组件 | 负责地图初始化、生命周期管理和子组件挂载 |
MapApiLoaderHOC | 异步加载器 | 保证百度地图 API 加载完毕再初始化组件 |
主要流程说明:
- Component基类 :作为所有地图组件的基类,继承自React的PureComponent,提供map实例、事件注册等基础功能。
- WrapperHOC :高阶组件封装,负责处理组件的事件绑定、属性更新等通用逻辑,通过registerEvents和toggleMethods等方法实现。
- Map组件 :核心地图组件,继承自Component基类,负责地图的初始化、生命周期管理以及子组件的渲染。
- MapApiLoaderHOC :地图API加载器,用于异步加载百度地图API,确保地图组件在API加载完成后初始化。
/*** @file 地图核心组件* @author hedongran* @email hdr01@126.com*/
import React, { ReactNode, ReactElement, CSSProperties } from 'react';
import { Component } from '../common';
import { Options } from '../common/WrapperHOC';
export interface MapProps {/** 中心点坐标 */center: BMapGL.Point | string;/** 缩放级别 */zoom: BMapGL.ZoomType;/** 地图初始化时的默认配置 */defaultOptions?: object;/** 个性化地图样式 */mapStyleV2?: BMapGL.MapStyleV2;/** 地图最小缩放级别 */minZoom?: BMapGL.ZoomType;/** 地图最大缩放级别 */maxZoom?: BMapGL.ZoomType;/** 地图类型,普通地图或地球模式 */mapType?: 'normal' | 'earth';/** 地图背景颜色,传rgba格式长度为4的数组 */backgroundColor?: number[];/** 地图显示配置 */displayOptions?: object;/** 地图旋转角度 */heading?: number;/** 地图倾斜角度 */tilt?: number;/** 是否开启鼠标滚轮缩放 */enableScrollWheelZoom?: boolean;/** 是否开启双击鼠标缩放 */enableDoubleClickZoom?: boolean;/** 是否开启地图旋转功能 */enableRotate?: boolean;/** 是否开启地图倾斜功能 */enableTilt?: boolean;/** 是否开启地图可拖拽缩放 */enableDragging?: boolean;/** 鼠标左键单击事件的回调函数 */onClick?(e: Event): void;/** 地图容器的class类名 */className?: string;/** 地图容器父元素的style样式 */style?: CSSProperties;
}
export interface MapContextProps {map?: BMapGL.Map;
}
export declare const MapContext: React.Context<MapContextProps>;
declare class Map extends Component<MapProps, {}> {private el;static defaultProps: MapProps | object;options: Options;constructor(props: MapProps);componentDidMount(): void;componentDidUpdate(prevProps: MapProps): void;componentWillUnmount(): void;initialize(): void;renderChildren(children: ReactElement | ReactElement[], map: BMapGL.Map): ReactNode;render(): JSX.Element;
}
declare const _default: typeof Map;
/*** 地图核心对象,地图控件、覆盖物、图层等需作为其子组件,以获得map的实例化对象* @visibleName Map 地图*/
export default _default;
export { default as MapApiLoaderHOC } from './MapApiLoaderHOC';
/*** @file 地图各子组件的高阶组件,用来处理绑定事件、属性等公共操作* @author hedongran* @email hdr01@126.com*/
import Component from './Component';
export declare type MapInstance = (BMapGL.Map | BMapGL.Overlay | BMapGL.Autocomplete | BMapGLLib.DrawingManager | BMapGLLib.DistanceTool);
export declare type Events = string[];
export declare type Options = string[];
export declare type Methods = {[x: string]: string[];
};
export declare function registerEvents(component: Component, instance: MapInstance, eventsMap?: Events): void;
export declare function unregisterEvents(component: Component, instance: MapInstance): void;
export declare function toggleMethods(component: Component, instance: MapInstance, methodsMap: Methods, prevProps?: {}): void;
export default function Wrapper<Comp>(Component: Comp, eventsMap?: Events, methodsMap?: Methods): Comp;
地图适配
这段代码从浏览器底层原理到React框架层面,实现了地图容器的智能尺寸适配,其工作原理可分为以下层次解析:
一、React框架层
-
useRef(null)
- 创建持久化引用,用于直接操作DOM元素(地图容器)
- 特点:引用值变化不会触发组件重新渲染
- 作用:保持对地图实例的稳定引用,避免因组件重渲染丢失地图对象
-
useState({width:0,height:0})
- 创建状态变量存储容器尺寸
- 特点:状态变化会触发组件重新渲染
- 作用:驱动地图重绘逻辑
-
useEffect(() => {...}, [])
- 副作用钩子,在组件挂载后执行
- 空依赖数组
[]
确保仅执行一次初始化逻辑 - 返回清理函数防止内存泄漏
二、浏览器事件层
-
window.addEventListener('resize', updateSize)
- 监听全局
resize
事件(浏览器窗口大小变化) - 事件触发时执行
updateSize
回调 - 底层原理:浏览器通过
EventLoop
将事件加入任务队列,以宏任务形式执行
- 监听全局
-
updateSize()
函数const container = document.querySelector('.map-container'); const newSize = {width: container.offsetWidth,height: container.offsetHeight }; setContainerSize(newSize);
document.querySelector
:通过CSS选择器查询DOM元素offsetWidth/offsetHeight
:获取元素布局尺寸(含边框、滚动条)setContainerSize
:更新状态,触发React重新渲染
三、地图渲染层
当容器尺寸变化时,触发以下地图库内部操作:
-
mapRef.current.map.resize()
- 调用百度地图API的
resize
方法 - 底层行为:
- 重新计算地图容器尺寸
- 触发视口(Viewport)更新
- 重新渲染地图瓦片(Tiles)
- 调整控件位置(如缩放按钮、比例尺)
- 调用百度地图API的
-
mapRef.current.map.reset()
- 强制重置地图状态
- 底层行为:
- 清除内部缓存
- 重新初始化渲染管线
- 确保极端尺寸变化下的稳定性
-
setViewport
- 显式设置地图视口参数
- 底层行为:
- 计算新的中心点坐标
- 调整缩放级别保证内容可见性
- 触发地理坐标系到像素坐标系的转换
四、浏览器渲染优化
-
强制同步布局(Forced Synchronous Layout)
- 代码通过
setTimeout
延迟执行resize
,避免在同一个事件循环中多次触发布局计算 - 防止因连续尺寸变化导致的性能问题(如滚动卡顿)
- 代码通过
-
CSS硬件加速
- 通过
transform: translateZ(0)
等属性触发GPU加速 - 底层原理:
- 创建新的复合层(Compositing Layer)
- 将渲染过程从主线程卸载到合成线程
- 减少重绘(Repaint)和回流(Reflow)开销
- 通过
五、响应式布局核心流程
-
初始化阶段
- 组件挂载 → 执行
useEffect
→ 绑定resize
事件 → 立即执行updateSize
获取初始尺寸
- 组件挂载 → 执行
-
尺寸变化阶段
- 窗口/容器尺寸变化 → 触发
resize
事件 → 执行updateSize
→ 更新containerSize
状态 → 触发React重新渲染
- 窗口/容器尺寸变化 → 触发
-
地图重绘阶段
- 状态更新 → 执行
useEffect
依赖containerSize
→ 调用地图API的resize
/reset
→ 触发地图库内部渲染流程
- 状态更新 → 执行
六、底层原理总结
这段代码通过React状态管理 + 浏览器事件监听 + 地图API调用的三层联动,实现了:
- 实时响应式布局:通过
resize
事件和状态更新,确保地图容器尺寸与视图同步 - 渲染性能优化:通过防抖(
setTimeout
)和硬件加速,减少不必要的计算开销 - 地图状态稳定性:通过
reset
和setViewport
,在极端尺寸变化下保持地图内容可见性和交互正常
其本质是建立了一个尺寸变化 → 状态更新 → 地图重绘的闭环反馈系统,符合浏览器渲染的事件驱动架构和响应式编程模型。
相关文章:
百度系列产品学习
1.react-bmapgl封装逻辑 Map 分析react-bmapgl库中Map组件的封装流程,并以mermaid图展示。首先分析Map组件的核心实现,包括生命周期方法和子组件渲染逻辑。然后研究WrapperHOC和Component基类的封装模式,理解事件绑定和属性处理的通用逻辑。…...
高等数学第三章---微分中值定理与导数的应用(3.4~3.5)
3.4 函数的单调性与曲线的凹凸性 一、函数的单调性 1. 函数单调性定义回顾 设函数 f ( x ) f(x) f(x) 的定义域为 D D D,区间 I ⊆ D I \subseteq D I⊆D。 如果对任意 x 1 , x 2 ∈ I x_1, x_2 \in I x1,x2∈I,当 x 1 < x 2 x_1 < x…...
idea结合CopilotChat进行样式调整实践
一、前言: 本文主要分享在前端开发中借助AI能力调整样式,提高开发效率 对应视频【idea结合CopilotChat进行样式调整实践-哔哩哔哩】 二、实践: 2-1、现状确认: 表格上方新增了button、swtich、select组件,需要调整…...
668SJBH报刊发行系统
1 前言 随着我国信息产业的迅猛发展,手工管理方式已不适应社务管理的要求,报社的日常管理正面临着信息化的挑战,采用计算机管理以提高服务质量和管理水平势在必行。发行管理是社务管理的一个重要组成部分,是报社和客户联系的纽带…...
格式化字符串漏洞
原理 在c中,printf函数在打印输出变量时通常不是直接输出,而是用一个占位符如%s printf("the number is %d\n",a);//通常用 printf(a);//而不是直接输出 虽然直接输出也没有太大的问题,但如果用格式化输出,没有给后面…...
如何查看电脑IP地址和归属地:全面指南
在数字化时代,了解自己电脑的IP地址和归属地信息变得越来越重要。无论是进行网络故障排查、远程办公设置,还是出于网络安全考虑,掌握这些基本信息都很有必要。本文将详细介绍如何查看电脑的公网IP、内网IP以及归属地信息,并提供常…...
深入解析 MQTT 协议:物联网通信的基石
在当今物联网蓬勃发展的时代,设备之间高效、可靠的通信变得至关重要。MQTT(Message Queuing Telemetry Transport)协议,作为一种轻量级的消息传输协议,正逐渐成为物联网通信的基石,广泛应用于各种场景中。 …...
48变现干货:分销裂变方式提高销量
产品运营活动中,我们可以根据对产品属性和特性,进行选择特定的方法,分销便是一种低成本各方获利的行为之一,但并不一定100%适用所有产品。 分销及裂变的概念 “分销”是指通过用户、达人、KOL等非官方渠道,参与产品的推广与销售,并获得相应收益的机制。它是一种以奖励为…...
AI入门:Prompt提示词写法
提示词(Prompt)是人与AI沟通的桥梁,它不是冰冷的代码指令,而是一场充满智慧与温度的对话。掌握精妙的提示词撰写技巧,能让AI更精准地理解需求,高效输出理想结果。其核心就在于——将AI视作身边真实的朋友、…...
MySQL复合查询全解析:从基础到多表关联与高级技巧
前言: 本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句 创建表的语句: DROP database IF EXISTS scott; CREATE database IF NOT EXISTS scott DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;USE scott;D…...
移动 Trae 目录到 E 盘 - 解决 C 盘空间不足问题
移动 Trae 目录到 E 盘 - 解决 C 盘空间不足问题 1️⃣ 准备工作2️⃣ 移动原始文件夹3️⃣ 创建符号链接4️⃣ 清理原始文件夹5️⃣ 验证操作📝 注意事项🔄 常见问题排查1️⃣ 准备工作 关闭 Trae 程序:确保所有 Trae 相关进程已完全退出(包括后台服务)。创建目标文件夹…...
【AI论文】COMPACT:从原子级到复杂级的组合式视觉能力调优
摘要:多模态大语言模型(MLLM)擅长简单的视觉语言任务,但在面对需要多种能力的复杂任务时却很吃力,例如同时识别物体、计算数量和理解它们的空间关系。 这可能部分是由于视觉指令调整(VIT)这一ML…...
【leetcode】队列 + 宽搜,树形结构层序遍历的基础与变化
前言 🌟🌟本期讲解关于力扣的几篇题解的详细介绍~~~ 🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客 🔥 你的点赞就是小编不断更新的最大动力 🎆那么废话不…...
Spring AI聊天模型API:轻松构建智能聊天交互
Spring AI聊天模型API:轻松构建智能聊天交互 前言 在当今数字化时代,智能聊天功能已成为众多应用程序提升用户体验、增强交互性的关键要素。Spring AI的聊天模型API为开发者提供了一条便捷通道,能够将强大的AI驱动的聊天完成功能无缝集成到…...
力扣-链表-2 两数相加
思路 两个指针同时遍历,维护一个进位值,同时还要维护第一个链表的前序,如果第二个链表比第一个长的时候,利用这个前序指针把第二个链表多余的内容,添加到第一个链表的末尾 代码 class Solution {public ListNode ad…...
leetcode 59. 螺旋矩阵 II
题目描述 代码: class Solution { public:vector<vector<int>> generateMatrix(int n) {vector<vector<int>> res(n,vector<int>(n,0));int num 1;int len n;int start 0;while(len > 0){int row start;int column start;if…...
【操作系统】深入理解内存管理:从虚拟内存到OOM Killer
引言 在现代计算机系统中,内存管理是操作系统最核心的功能之一。本文将围绕内存管理的几个关键概念展开讨论,包括虚拟内存机制、内存分配原理、OOM Killer的工作机制以及不同系统架构下的内存限制。 虚拟内存:突破物理限制的关键技术 虚拟…...
《政治最后的日子》章节
政治与中世纪教会的类比性衰落 作者提出现代民族国家正重复中世纪教会的衰落轨迹: 两者均曾作为社会组织核心存在约5个世纪 晚期都成为生产力阻碍(中世纪教会税收负担/现代国家官僚低效) 末期均出现管理者普遍腐败与公众蔑视(…...
Rust Trait 学习
概述 特征(trait)是rust中的概念,类似于其他语言中的接口(interface)。特征定义了一个可以被共享的行为,只要实现了特征,你就能使用该行为。 如果不同的类型具有相同的行为,那么我们…...
基于开源链动2+1模式AI智能名片S2B2C商城小程序的爆品力构建研究
摘要:在兴趣电商生态中,爆品力已成为品牌实现指数级增长的核心竞争力。本文以开源链动21模式AI智能名片S2B2C商城小程序为技术载体,结合抖音平台的内容传播特性,提出“需求挖掘-技术赋能-内容转化”三位一体的爆品力构建模型。通过…...
【SimSession 】2:PacedReceiver:支持与 PacedVideoSender 本地联调
单独的基于libuv的发送能力,如何进一步在SimSession内集成使用?打算进行本地模拟俩线程,发送和接收,进行测试: 单独的发送测试 【SimSession】1:将视频发送逻辑与 libuv 事件循环集成是一个典型的并发设计问题 分析后,D:\XTRANS\thunderbolt\ayame\zhb-bifrost\player-…...
5 什么情况下需要微调
这个问题其实很重要,因为现代大模型训练出来已经非常强大,可能真的不需要微调。 我们可以通过 RAG 或提示词工程来实现目标。 需要微调的场景与替代方案分析 微调(Fine-tuning)确实不是所有场景都必需的,特别是考虑到现代大型语言模型(LLM…...
Docker 渡渡鸟镜像同步站 使用教程
Docker 渡渡鸟镜像同步站 使用教程 🚀 介绍 Docker.aityp.com(渡渡鸟镜像同步站)是一个专注于为国内开发者提供 Docker 镜像加速和同步服务的平台。它通过同步官方镜像源(如 Docker Hub、GCR、GHCR 等),为…...
位图的实现和拓展
一:位图的介绍 ①:需要位图的场景 给40亿个不重复的无符号整数,没排过序。给一个无符号整数,如何快速判断一个数是否在这40亿个数中? 要判断一个数是否在某一堆数中,我们可能会想到如下方法: A…...
字符串问题c++
题目描述 小 Z 有一个字符串 s,他对这个字符串会进行如下两个操作: 1 p c 把字符串的第 p 个字符改成 c2 l r 把 s 的第 l 个字符到第 r 个字符按顺序输出。 这里『第 i 个字符』的下标计数从 1 开始,例如,a 是字符串 abc 的第…...
Redis事务
Redis中的事务是指提供一种将多个命令打包到一起,一次性按照顺序执行的机制。Redis在执行事务期间,不会接收处理其他操作命令。 Redis事务有以下局限性 无回滚机制:如果某个命令执行失败,不会影响其他命令的执行,因此…...
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】3.3 异常值识别(Z-score法/IQR法/业务规则法)
👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 PostgreSQL数据分析实战:数据质量分析之异常值识别(Z-score法 / IQR法 / 业务规则法)3.3 异常值识别3.3.1 Z-score法3.3.2 IQR法3.3.3 业…...
MCP底层协议完整通信过程
2025 年是智能体的元年, 也注定是智能体集中爆发的一年! 两个互联领域的重大挑战: 第一、 Agent 与 Tools (工具)的交互 Agent 需要调用外部工具和 API...
C语言 指针(5)
目录 1.冒泡排序 2.二级指针 3.指针数组 4.指针数组模拟二级数组 1.冒泡排序 1.1 基本概念 冒泡排序(Bubble Sort) 是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元 素,如果它们的顺序错误就把它…...
MYSQL-联合查询
经过上节课,我们学会了如何设计表以及了解到各种范式,这节课就请大家和小L一起来学习设计表之后如何使用 1.为什么要使用联合查询 在数据设计时由于范式的要求,数据被拆分到多个表中,那么要查询⼀个条数据的完整信息,…...
一篇撸清 Http,SSE 与 WebSocket
HTTP,SSE 和WebSocket都是网络传输的协议,本篇快速介绍三者的概念和比较。 SSE(Server-Sent Events) 是什么? SSE(Server-Sent Events),服务器发送事件, 是一种基于 HTTP 的轻量级协议,允许服务器主动向客户端(如浏览器)推送实时数据。它设计用于单向通信(服务器到…...
系统架构设计师:设计模式——行为设计模式
一、行为设计模式 行为模式涉及算法和对象间职责的分配。行为模式不仅描述对象或类的模式,还描述它们之间的通信模式。这些模式刻画了在运行时难以跟踪的、复杂的控制流。它们将用户的注意力从控制流转移到对象间的联系方式上来。 行为类模式使用继承机制在类间分…...
OpenCV入门指南:从环境搭建到第一个图像处理程序
引言 你是否想让计算机"看懂"世界?OpenCV(Open Source Computer Vision Library)正是打开计算机视觉大门的钥匙。本文将带你从零开始搭建开发环境,理解图像处理核心概念,并完成第一个OpenCV程序。无论你是想…...
基于STM32的温湿度光照强度仿真设计(Proteus仿真+程序设计+设计报告+讲解视频)
这里写目录标题 **1.****主要功能****2.仿真设计****3.程序设计****4.设计报告****5.下载链接** 基于STM32的温湿度光照强度仿真设计(Proteus仿真程序设计设计报告讲解视频) 仿真图Proteus 8.9 程序编译器:keil 5 编程语言:C语言 设计编号…...
4个纯CSS自定义的简单而优雅的滚动条样式
今天发现 uni-app 项目的滚动条不显示,查了下原来是设置了 ::-webkit-scrollbar {display: none; } 那么怎么用 css 设置滚动条样式呢? 定义滚动条整体样式 ::-webkit-scrollbar 定义滚动条滑块样式 ::-webkit-scrollbar-thumb 定义滚动条轨道样式…...
修复笔记:SkyReels-V2项目中的 from_config 警告
#工作记录 Windows避坑部署SkyworkAI/SkyReels-V2昆仑万维电影生成模型_skyreels-v2本地部署-CSDN博客 一、项目背景 项目名称:SkyReels-V2 项目简介:由昆仑万维开源的全球首个无限时长电影生成模型,支持文本到视频、图像到视频等多种生成方…...
[硬件电路-11]:模拟电路常见元器件 - 什么是阻抗、什么是输入阻抗、什么是输出阻抗?阻抗、输入阻抗与输出阻抗的全面解析
1. 阻抗(Impedance) 定义:阻抗是电路或元件对交流信号(AC)流动的阻碍能力,用符号Z表示,单位为欧姆(Ω)。它综合了电阻(R)、电感(L&am…...
MCP协议与Dify集成教程
一、MCP协议概述 MCP(Model Control Protocol)是一种新兴的开放协议,为大型语言模型(LLM)与外部应用之间构建了双向通信通道。它就像是AI的"USB-C"接口,帮助模型发现、理解并安全调用各种外部工…...
flink常用算子整理
文章目录 前言1.重新分配(即打散)2.合并流的算子3.算子链操作4.侧边输出(目前只有一种)5.键控进行分区6.输出算子7.其他基础操作算子8.其他常用的算子9.Flink窗口等情况10.窗口举例前言 提示:以下是本篇文章正文内容,下面案例可供参考 1.重新分配(即打散) 2.合并流的算子 3…...
【SimSession】1:将视频发送逻辑与 libuv 事件循环集成是一个典型的并发设计问题
之前对SimSession的信令进行测试,echo可以与relay联通,现在单独提取 已经集成了webrtc的发送模块及libuv框架与SimSession和echo集成: 采集、编码和发送之前在pacedsender内部实现的 现在从pacedsender中去掉采集、编码,放在session中运行。 而pacedsender仅暴露发送部分:…...
Circular Plot系列(五): circle plot展示单细胞互作
这是我们circle系列的最后一节,我想常见的弦图是绕不开的,所以最后从前面介绍的circle plot思路,做一遍弦图。其实前面的内容如果消化了,plot互作弦图也就不成什么问题了。 效果如下: #cellchat提取互作结果ÿ…...
LLama-v2 权重下载
地址:llama模型 官方github仓库:llama仓库 注意点 网络代理位置:美国下面的国家选择 United States 克隆仓库后 运行bash download.sh输入邮箱收到的URL选择要下载的权重等待下载完成即可 有问题留言!!!…...
深入解析Linux进程间通信(IPC):机制、应用与最佳实践
引言 在多任务操作系统中,进程间通信(Inter-Process Communication, IPC)是协同工作的核心机制。Linux作为现代操作系统的典范,提供了8种主要IPC方式,从传统的管道到面向网络的套接字,每种方法都暗藏独特的…...
基于开源AI大模型AI智能名片S2B2C商城小程序源码的私域流量稳定性构建研究
摘要:在私域流量时代,传统实体零售的"时间积累"逻辑被直播电商等新业态颠覆。完美日记等新锐品牌通过构建私域流量池,实现了从0到1的指数级增长,而传统品牌却陷入"流量焦虑"。本文提出以开源AI大模型AI智能名…...
第13章:陈默再访海奥华
第13章:陈默再访海奥华 第一节:启程——穿越虫洞的旅程 2046年,赤色世界的和平与繁荣达到了前所未有的高度。人类已经完成了从物质文明向意识文明的转变,精神力的普及让每一个人都拥有了学习、修复和感知的能力。然而࿰…...
Prompt compress 技术探究-LLMLingua2
LLMLingua2 https://arxiv.org/pdf/2403.12968是LLMLingua的改进版本。我们知道 LLMLingua需要用小模型压缩,模型太小不一定能保证性能,模型太大耗费时间又太长。这个方法理论上可以,但实际上不是很方便用。很难选择到合适的小模型。 小模型…...
【机器学习案列-22】基于线性回归(LR)的手机发布价格预测
🧑 博主简介:曾任某智慧城市类企业算法总监,目前在美国市场的物流公司从事高级算法工程师一职,深耕人工智能领域,精通python数据挖掘、可视化、机器学习等,发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…...
python调用国税乐企直连接口开数电票之获取数字化电子发票批量预赋码信息
乐企平台介绍 乐企平台作为国家税务总局推出的唯一数电票标准化的API接口重要平台,旨在通过税务系统与企业自有信息系统的直连涉税服务,开票员登录企业自有系统(ERP、OMS、发票管理系统等)无需通过第三方平台即可实现国税直连开票…...
Axure打开html文件失败,解决方案:
1、在原型文件中找到 2、文件后缀名改为 axure-chrome-extension.rar ,解压后到axure-chrome-extension 3、打开Chrome浏览器,找到扩展程序 选择刚刚解压的文件axure-chrome-extension文件夹,配置完成,打开html试试吧...
Android第四次面试总结之Java基础篇(补充)
一、设计原则高频面试题(附大厂真题解析) 1. 单一职责原则(SRP)在 Android 开发中的应用(字节跳动真题) 真题:“你在项目中如何体现单一职责原则?举例说明。”考点:结合…...