从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,一经查实,立即删除!

相关文章

Blender常见操作

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

二、VLAN原理和配置

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

字节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】✨︎ 在本专栏中不仅包含一些适合初学者的最新机器学习项目,每个项目都处理一组不同的问题,包括监督和无监督学习、分类、回归和聚类,而且涉及创建深度学…

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

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

Kubernetes学习笔记06

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

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

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

H266 编码标准开源编码器 VVenC 介绍

H266 H.266,也称为VVC(Versatile Video Coding),是最新的国际视频编码标准,由MPEG(Moving Picture Experts Group)和ITU(International Telecommunication Union)联合开…

MySQL CRUD操作

前言👀~ 上一章我们介绍了数据库的一些基础操作,关于如何去创建一个数据库,还有使用数据库,删 除数据库以及对表进行的一些基础操作,今天我们学习CRUD操作 俗称(增删改查) 如果各位对文章的内…

IDM下载器安装cmd注册

一、下载注册 安装包去IDM官网下载最新的试用版即可 或者直达百度网盘下载(担心被河蟹,放在txt中了)包含IDM下载器安装包和注册软件 IDM下载器安装包和注册软件下载地址链接 https://download.csdn.net/download/qq_31237581/89215452 如果…

【STM32+HAL】SDIO模式读写SD卡

一、准备工作 有关CUBEMX的初始化配置,参见我的另一篇blog:【STM32HAL】CUBEMX初始化配置 二、所用工具 1、芯片: STM32F407ZGT6 2、IDE: MDK-Keil软件 3、库文件:STM32F4xxHAL库 三、实现功能 实现用DMA读写SD卡内…

人工原生动物优化器(APO)-2024年SCI一区新算法-公式原理详解与性能测评 Matlab代码免费获取

声明:文章是从本人公众号中复制而来,因此,想最新最快了解各类智能优化算法及其改进的朋友,可关注我的公众号:强盛机器学习,不定期会有很多免费代码分享~ 目录 原理简介 一、觅食行为 (1)自养模式 (2)异…

xss漏洞学习

1.xss漏洞简介 跨站脚本(Cross-Site Scripting),本应该缩写为CSS,但是该缩写已被层叠样式脚本Cascading Style Sheets所用,所以改简称为XSS。也称跨站脚本或跨站脚本攻击。 原理:跨站脚本攻击XSS通过将恶…

项目文档:基于JavaFX + Maven的桌面扫雷软件打包exe【小白可做,文章末尾有包教安装有源代码可运行,可打包】

微信公众号: 科研小条 前言 用于学习javafx做桌面软件,熟悉maven构建项目的最佳选择 效果展示: 1. 项目概述 本项目是一个基于Java和JavaFX构建的桌面扫雷游戏软件。扫雷游戏是一种经典的单人益智游戏,玩家需要根据已知的雷区信息&…

Golang Colly爬取图片gorm存储数据

语言:Golang 库:Iris/Colly/gorm 运行结果 text/html; charset=utf-8 It is image 20240429222029_0_0.jpg Saved file: images\20240429222029_0_0.jpg text/html; charset=utf-8 It is image 20240429222030_1_0.jpg Saved file: images\20240429222030_1_0.jpg It is ima…

动态切换数据源的最佳实践

序言 本文和大家聊聊在开发中,动态切换多数据源的方案。 一、多数据源需求 随着应用程序的发展和复杂性增加,对于多数据源的需求也变得越来越普遍。在某些场景下,一个应用程序可能需要连接和操作多个不同的数据库或数据源。常见的场景包括…

Qt QThreadPool线程池

1.简介 QThreadPool类管理一个QThread集合。 QThreadPool管理和重新设计单个QThread对象,以帮助降低使用线程的程序中的线程创建成本。每个Qt应用程序都有一个全局QThreadPool对象,可以通过调用globalInstance来访问该对象。 要使用其中一个QThreadPool…

深度学习入门(4)

神经网络的构建 import numpy as np import matplotlib.pyplot as plt def sigmoid(x):return 1/(1np.exp(-x)) def identity_function(x):#恒等函数return x def init_network():#进行权重和偏置的初始化,并保存到字典中network{}network[W1]np.array([[0.1,0.3,0…