从0开始学习制作一个微信小程序 学习部分(2)json文件的说明与app.json文件的操作

系列文章目录

本文是小程序制作系列的学习篇的第二篇
学习篇第一篇我们讲了编译器下载,项目、环境建立、文件说明与简单操作:第一篇链接
本篇将继续讲解一些基础的编码,分析json文件的作用,着重讲解app.json里可以对小程序进行的切换页面,改变图标等操作。


文章目录

  • 系列文章目录
  • 一、json文件的性质
  • 二、json文件的操作
      • 1)控制封面页
      • 2)控制页面window
        • a) window简介
        • b)window配置项
      • 3) tabBar
        • a) 列表对象添加
        • b) 样式设置
        • c)样式设置(续)
          • 1.边线颜色
          • 2.表单位置
  • 三、本段完整代码
  • 总结


一、json文件的性质

上文说到,app.json文件是全局配置文件,实际上,所有的.json文件都是配置文件。

在这里插入图片描述
我们查看目录,有很多.json文件。
App.json全局配置,设置全局变量和页面路由逻辑;
页面中的json 配置页面的窗口样式,标题。
Project.config.json 保存配置信息和开发者个人设置。
Sitemap.json 配置检索信息,提高被搜索到的概率。

二、json文件的操作

1)控制封面页

在这里插入图片描述

我们打开app.json,我们可以用 "entryPagePath": "pages/index/index",
来控制封面页,如果没有entrypath,则自动设置page中第一项配置页。

2)控制页面window

a) window简介

在这里插入图片描述
在各个的pages下面,是window,是用于控制小程序的状态栏,导航,标题和窗口颜色的。

在这里插入图片描述

b)window配置项

在这里插入图片描述

  "navigationBarTitleText": "标题测试","navigationBarBackgroundColor": "#f3514f","enablePullDownRefresh": true,"backgroundColor": "#efefef","backgroundTextStyle": "dark"

这几个是我们常用的配置项。
首先是第一条,意思是设置标题。第二行设置状态和导航栏的颜色。
第三行设置是否允许下拉刷新,第四行设置下拉刷新的颜色,图中是灰色。
最后一行设置下拉刷新那三个小点是什么颜色,我们这里选dark就是暗色。

3) tabBar

a) 列表对象添加
   "tabBar": {"list": [{"pagePath": "pages/index/index","text": "测试_index","iconPath": "/assets/tabbar/index.png","selectedIconPath": "/assets/tabbar/selected.png"},{"pagePath": "pages/test_4/test_4","text": "测试_4","iconPath": "/assets/tabbar/index.png","selectedIconPath": "/assets/tabbar/selected.png"}]},

在这里插入图片描述
以上代码实现了程序下面的可以切换页面的tab栏。
pagepath是点击后跳转的页面。text是显示的文本。iconpath是为点击时的图标,selectediconpath是点击后的图标。

如果我点击测试4,则会切换为激活图标,如上图所示,蓝色图标是未激活图标,表情包是激活后图标。注意,图标图片需要在40kb以下,也可以用绝对路径引入,图标可以从iconpark等等地方寻找。
注意,你需要自己创建assets文件夹并将图片放进去!!
注意,list中至少要两个以上!!
注意tab之后的大括号后面逗号不要忘记!!

b) 样式设置

在tabbar中与list同级还有一些设置,如下:

 "selectedColor": "#f3514f","color": "#666","backgroundColor": "#efefef",

selectedcolor是被选中时字体的颜色,之前是绿色,现在我们改成红色,如图
在这里插入图片描述
color是未被选中时的颜色。
backgroundcolor时整个栏目的背景颜色,efefef是灰色,为了方便展示,我将改为f3514f红色,显示如下
在这里插入图片描述

c)样式设置(续)
1.边线颜色

先讲我们的 "borderStyle": "black",在这里插入图片描述
是修改我上图中圈起来的线是否显示的,默认是显示。

2.表单位置

再讲我们的position,我们的tabbar默认在底部,我们也可以把他调到顶部。
在这里插入图片描述
只需要这么写就行了"position": "top",对应的底部为botton
注意,在顶部的时候,图标(icon)是不显示的。


三、本段完整代码


{"entryPagePath": "pages/index/index","pages": ["pages/index/index","pages/list/list","pages/test_3/test_3","pages/test_4/test_4"],"window": {"navigationBarTitleText": "标题测试","navigationBarBackgroundColor": "#f3514f","enablePullDownRefresh": true,"backgroundColor": "#efefef","backgroundTextStyle": "dark"},"tabBar": {"selectedColor": "#f3514f","color": "#666","backgroundColor": "#efefef","borderStyle": "black","position": "bottom","list": [{"pagePath": "pages/index/index","text": "测试_index","iconPath": "/assets/tabbar/index.png","selectedIconPath": "/assets/tabbar/selected.png"},{"pagePath": "pages/test_4/test_4","text": "测试_4","iconPath": "/assets/tabbar/index.png","selectedIconPath": "/assets/tabbar/selected.png"}]},"style": "v2","sitemapLocation": "sitemap.json","lazyCodeLoading": "requiredComponents"
}

注: 以上代码是app.json文件

总结

本文讲述了app.json里的诸多操作,是我们经常要使用的,请熟悉使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/5015.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小米金融守护消费权益,共筑金融和谐新篇章

随着金融市场的日益成熟,金融消费者的权益保护问题逐渐受到广泛关注。作为金融服务体系中的重要一环,保护消费者权益不仅是金融机构的基本职责,更是其长远发展的基石。小米金融聚焦于金融消费者权益保护,通过梳理典型案例&#xf…

C语言初阶--指针

文章目录 1. 指针是什么?2. 指针和指针类型2.1. 指针类型2.2. 指针类型的意义 3. 野指针3.1. 野指针成因3.1.1. 未初始化3.1.2. 超过数组范围,越界访问3.1.3. 指针指向的空间释放 3.2. 规避野指针 4. 指针运算4.1. 指针-整数4.2. 指针 - 指针4.3. 指针的关系运算 5. 指针和数组…

Blender常见操作

1.局部视图:Local View,也可称作Solo模式,按快捷键 “/”进入,在按退出,只显示选中的物体(可多选),方便编辑 2.物体合并:Ctrl J 其中,当选中多个物体时&am…

二、VLAN原理和配置

vlan不是协议,是一个技术,虚拟局域网技术,基于802.1q协议。 vlan(虚拟局域网),将一个物理的局域网在逻辑上划分成多个广播域的技术。 目录 1.冲突域和广播域 概念 范围 2.以太网帧格式 3.以太网帧封装…

Python基础:【扩展系列】Python对小程序或App进行自动化操作常用框架

Python可以用来实现对小程序或App的自动化操作,这通常涉及使用专门的自动化测试和操作工具。 常用框架 以下是一些常用的工具和框架: Appium: Appium 是一个开源工具,用于自动化移动应用程序的测试,包括原生应用、移动网页应用和混合应用。它支持iOS、Android和Windows应…

【酱浦菌-爬虫项目】四种方法爬取百度首页信息

项目原理: 首先,定义了四个函数,每个函数都有不同的功能: func1():发送一个GET请求到百度网站,并获取响应内容,演示如何使用requests库来获取网页内容。 func2():发送一个GET请求到…

字节5面挂,恶心到了。。。

字节五面 今天脉脉看到一篇帖子: 楼主是 tx 的前员工,在字节五面(加轮)被挂后,认定(或许私下做了一些调查)是字节 HR 向 tx 背调,然后被前同事捏造虚假信息,导致的面试失…

分类规则挖掘(一)

目录 一、分类问题概述(一)分类规则挖掘(二)分类规则评估(三)分类规则应用 二、k-最近邻分类法 一、分类问题概述 动物分类:设有动物学家陪小朋友林中散步,若有动物突然从小朋友身边…

【Linux】yum、vim

🌈个人主页:秦jh__https://blog.csdn.net/qinjh_?spm1010.2135.3001.5343🔥 系列专栏:https://blog.csdn.net/qinjh_/category_12625432.html 目录 Linux 软件包管理器 yum 什么是软件包 查看软件包 如何安装软件 如何卸载软…

机器学习:基于Sklearn、XGBoost框架,使用逻辑回归、支持向量机和XGBClassifier来诊断并预测一个人是否患有自闭症

前言 系列专栏:机器学习:高级应用与实践【项目实战100】【2024】✨︎ 在本专栏中不仅包含一些适合初学者的最新机器学习项目,每个项目都处理一组不同的问题,包括监督和无监督学习、分类、回归和聚类,而且涉及创建深度学…

清理 Conda 和 pip 缓存

清理 Conda 缓存 查看 Conda 缓存的使用情况 conda clean --dry-run --all 删除不再使用的包和缓存 conda clean --all 清理 pip 缓存 Python缓存文件的默认位置: Windows 10:C:\Users\username\AppData\Local\pip\Cache macOS:/Users/…

JAVA系列 小白入门参考资料 继承

目录 1. 为什么需要继承 2. 继承的概念 3. 继承的语法 4. 父类成员访问 4.1 子类中访问父类的成员变量 1. 子类和父类不存在同名成员变量 2. 子类和父类成员变量同名 4.2 子类中访问父类的成员方法 1. 成员方法名字不同 2. 成员方法名字相同 ​5. super关键字 …

Kubernetes学习笔记06

第十六章、Kubernetes容器交付介绍 如何在k8s集群中部署Java项目 容器交付流程 开发代码阶段 编写代码编写Dockerfile【打镜像做准备】持续交付/集成 代码编译打包制作镜像上传镜像仓库应用部署 环境准备PodServiceIngress运维 监控故障排查应用升级 k8s部署Java项目流程 …

AI在建筑行业中的现状

1、关键发现: -AI正逐渐成为建筑师工作流程的一部分,其发展受到实验和自学的推动。 -使用AI的设计师对其在项目早期阶段的应用最为满意,尽管有些人在其他地方也找到了创新用途。 -当前建筑领域内缺乏AI的规范和道德指导,引起了一些担忧。 -关于AI在建筑中的位置存在不同意…

使用Github+Picgo+npm实现免费图床

本文参考自 Akilar,原文地址:https://akilar.top/posts/3e956346/ Picgo的配置 Github图床仓库内容不能超过1GB,因为Github原则上是反对仓库图床化的,超过1GB之后会由人工审核仓库内容,如果仓库被发现用来做图床&…

如何解决Go中uint类型溢出问题

如何解决Go中uint类型溢出问题 Golong的uint类型溢出问题通常会发生在大量的运算中,特别是涉及到大量循环和大数运算中。当uint类型的值超过其最大值时,会发生溢出,从最小值开始循环,一般有如下几种解决办法: 1. 使用…

Spring Boot项目中集成Logback作为日志框架-笔记

在Spring Boot项目中集成Logback作为日志框架是一个标准做法,因为Spring Boot默认就使用Logback作为日志系统。以下是集成Logback的步骤: 1. 默认集成 Spring Boot会自动配置Logback,所以通常情况下,你不需要添加任何额外的依赖或…

介绍一下mybatis的基本配置(mybatis-config.xml)

src/main/resources/mybatis-config.xml 这句代码&#xff0c;是XML的声明&#xff0c;它指定了&#xff0c;XML的版本 和 编码方式 <?xml version"1.0" encoding"UTF-8" ?>这句代码&#xff0c;声明了XML文档类型&#xff0c;它告诉解析器&#x…

RTCRTC

#include "stm32f10x.h" void MyRTC_Init(void) { //1.开启PWR和BKP的时钟 使能BKP和RTC的访问 RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR,ENABLE); RCC_APB1PeriphClockCmd(RCC_APB1Periph_BKP,ENABLE); PWR_BackupAccessCmd(ENABLE); …

MongoDB的安装与操作

MongoDB的安装 MongoDB的使用与封装安装&#xff1a; 1、官网下载地址&#xff1a;https://www.mongodb.com/try/download/community 2、安装mongodb-windows-x86_64-4.4.28-signed.msi 3、安装Robo3T客户端robo3t_v1.4.3.ziphttps://robomongo.org/&#xff08;客户端MongoD…