uniapp使用navigator标签不支持flex布局

前言

今天使用uniapp开发时,选用navigator作为flex布局容器 ,内部元素水平排列,可是发现微信小程序生效,网页端不生效

微信小程序效果如下:

网页端效果如下:

源代码如下:

html 复制代码
<template>
	<view class="root">
		
		<text>navigator容器使用flex布局</text>
		<navigator class="navigator-box">
			<view class="box1"></view>
			<view class="box2"></view>
			<view class="box3"></view>
		</navigator>
		
		<text>view使用flex布局</text>
		<view class="view-box">
			<view class="box1"></view>
			<view class="box2"></view>
			<view class="box3"></view>
		</view>
		
	</view>
</template>
<style lang="scss" scoped>
	
	.root {
		// navigator标签设置flex布局在网页端不生效
		.navigator-box {
            //	设置水平flex布局	
			display: flex;
			flex-direction: row;
		}
		
		.view-box {
            //	设置水平flex布局	
			display: flex;
			flex-direction: row;
		}
		
		.box1 {
			background-color: red;
			width: 100px;
			height: 100px;
		}
		.box2 {
			background-color: green;
			width: 100px;
			height: 100px;
		}
		.box3 {
			background-color: blue;
			width: 100px;
			height: 100px;
		}
		text {
			display: block;
			margin: 20px 50px;
			font-size: 20px;
			
		}
	}
</style>

使用navigator标签要注意的坑

① navigator标签在非小程序端(如网页端、安卓端) 不支持flex布局

② navigator标签在非小程序端(如网页端、安卓端) 不支持css的一级子元素选择器 (如 navigator>view,不能在网页端选中navigator标签内部的一级子元素view)

问题解决

如果需要对navigator内部的元素进行样式调整,就将navigator内部的所有元素用view容器包裹,然后对这个view容器进行css修饰

上面的代码出现的不兼容问题调整之后源码如下:

html 复制代码
<template>
	<view class="root">
		
		<text>navigator容器使用flex布局</text>
		<navigator class="navigator-box">
			<!-- 将navigator内部所有元素用一个view容器包裹,然后对view容器单独修饰 -->
			<view class="container">
				<view class="box1"></view>
				<view class="box2"></view>
				<view class="box3"></view>
			</view>
		</navigator>
		
		<text>view使用flex布局</text>
		<view class="view-box">
			<view class="box1"></view>
			<view class="box2"></view>
			<view class="box3"></view>
		</view>
		
	</view>
</template>
<style lang="scss" scoped>
	
	.root {
		.container {
			display: flex;
			flex-direction: row;
		}
		
		.view-box {
			display: flex;
			flex-direction: row;
		}
		
		.box1 {
			background-color: red;
			width: 100px;
			height: 100px;
		}
		.box2 {
			background-color: green;
			width: 100px;
			height: 100px;
		}
		.box3 {
			background-color: blue;
			width: 100px;
			height: 100px;
		}
		text {
			display: block;
			margin: 20px 50px;
			font-size: 20px;
			
		}
	}
</style>
相关推荐
徐子童15 小时前
网络协议---TCP协议
网络·网络协议·tcp/ip·面试题·1024程序员节
扫地的小何尚2 天前
NVIDIA RTX PC开源AI工具升级:加速LLM和扩散模型的性能革命
人工智能·python·算法·开源·nvidia·1024程序员节
数据皮皮侠AI3 天前
上市公司股票名称相似度(1990-2025)
大数据·人工智能·笔记·区块链·能源·1024程序员节
开开心心就好4 天前
系统清理工具清理缓存日志,启动卸载管理
linux·运维·服务器·神经网络·cnn·pdf·1024程序员节
Evan东少6 天前
[踩坑]笔记本Ubuntu20.04+NvidiaRTX5060驱动+cuda+Pytorch+ROS/Python实现人脸追踪(环境准备)
1024程序员节
不爱编程的小陈7 天前
C/C++每日面试题
面试·职场和发展·1024程序员节
开开心心就好8 天前
右键菜单管理工具,添加程序自定义名称位置
linux·运维·服务器·ci/cd·docker·pdf·1024程序员节
码农三叔8 天前
(4-2-05)Python SDK仓库:MCP服务器端(5)Streamable HTTP传输+Streamable HTTP传输
开发语言·python·http·大模型·1024程序员节·mcp·mcp sdk
西幻凌云12 天前
初始——正则表达式
c++·正则表达式·1024程序员节
启芯硬件13 天前
电源XL6009E1的dieshot细节分析-芯片设计干货
大数据·经验分享·硬件工程·1024程序员节