后端开发是如何搞定APP开发的--《前端那些事》

简介: 个人技术背景:从业10年,一直做后端相关的开发工作,对JavaScript的基本语法有一定的了解,完成过公司内的运营后台的前端开发工作,使用boostrap来解决窗口适配等问题,对前端知识的掌握停留在jQuery及基本的页面逻辑编写上。近几年对APP开发有浓厚兴趣,想独立将自己的想法通过APP落地实现出来,期间接触过ios开发swift,Android开发,以及一些前端框架phonegap、flutter以及vue,目前通过flutter以及vue搭建出了APP,当前处于发行前期。本篇文章旨在向大家介绍作为一名多年经验的后端开发,是如何一步一步的独立实现APP的开发和搭建前端部分的工作的。

讨论范围


2010年以前,前端开发一般指的是网站端将页面翻译成JavaScript,并对多种浏览器比如IE、Firefox、Opera、世界之窗等做兼容;随着Chrome的崛起以及移动互联网的普及,跨端的前端框架如雨后春笋般出现,从Facebook的reactjs到Google的flutter(立意点是一处写多端用提升效率降低成本,并尽可能减小相比于原生开发语言带来的性能影响),再到各个应用程序的小程序,近十年,相比于其他的开发者,前端开发者的世界可谓是轰轰烈烈。


所以当下的前端,它不再仅仅指代以往的前端开发(将页面通过JavaScript实现出来),它还包括终端开发(包括Android、IOS以及其他的一些端)、跨端开发、小程序开发、视觉UI设计等。标准的软件开发流程大致如下:


用户调研  ->  产品原型  ->  视觉设计  ->  前端开发  ->  后端开发  ->  测试上线


可以看到,从用户调研完成开始到后端开发之前,其实都是前端开发的范畴,有些公司会分类为前台、中台、后台。


而本文,我们讨论的范围是作为一名后端开发,如何独立实现APP的开发上线。

技术选型

当前,APP主要分为Android和IOS两个系统平台,其中Android开发语言为Kotlin、Java(Google在2019正式宣布kotlin代替Java成为Android开发的首选语言),IOS的开发语言为Swift、Objective-C。


一个人同时掌握多套终端开发技能是不难的,然而作为一名有追求的程序员,最大的特质是懒,即同样的逻辑是不太愿意重复实现的,另外也比较浪费时间;另外,IOS开发需要向苹果公司购买证书,个人开发者每年99美元,我们只是先自己折腾一下,短期内考虑只推出Android平台的app就好。


基于以上,我决定选择一种跨端的框架来实现。


上手试试


开发工具:

Android studio  Google官方提供的IDE,我这里用于跑Android模拟器

HBuilderX         UNIAPP官方提供的IDE,用于开发app页面逻辑


uniapp项目常规的目录结构及解释如下:(注:App.vue和main.js的注释写反了)

image.png


以简单的用户信息页面为例,模板代码如下:

<template><viewclass="user-info-root"><viewclass="user-info-item user-info-item-avatar"><viewclass="user-info-item-title">        头像
</view><viewclass="user-info-item-value"><imageclass="user-info-item-value-avatar":src="userInfo.avatarUrl"mode="aspectFill"></image></view><!-- <view class="user-info-item-go-to"></view> --></view><viewclass="user-info-item"@click="goToUpdateName"><viewclass="user-info-item-title">        昵称
</view><viewclass="user-info-item-value">        {{userInfo.nick}}
</view><viewclass="user-info-item-go-to"></view></view><viewclass="user-info-item"@click="goToUpdateGender"><viewclass="user-info-item-title">        性别
</view><viewclass="user-info-item-value">        {{userInfo.gender === 1 ? '男' : '女'}}
</view><viewclass="user-info-item-go-to"></view></view><navigatorclass="user-info-item"url="/pages/cityList/cityList"><viewclass="user-info-item-title">        地区
</view><viewclass="user-info-item-value">        {{userInfo.province}} {{userInfo.city}}
</view><viewclass="user-info-item-go-to"></view></navigator><viewclass="user-info-item"@click="goToUpdateDescription"><viewclass="user-info-item-title">        个人描述
</view><viewclass="user-info-item-value">        {{userInfo.description}}
</view><viewclass="user-info-item-go-to"></view></view></view></template>

获取数据的逻辑如下:

asyncloadUserInfo() {
uni.showLoading({
title: '数据加载中...'  });
let [userInfoData] =awaithttpUtils.postJson("/api/user/info", {});
this.userInfo=userInfoData.data;
uni.hideLoading();
},

虚拟机展示效果:

image.png


涉及后端的表结构设计、HTTP接口的提供这里就不展开了。

至此,在模拟器上我们可以顺利的创建页面、编写逻辑、渲染页面了。


经过两个多月的开发,APP已基本成型,页面端向大家分享一下:

image.pngimage.pngimage.png


总结

随着移动互联网的发展,前端领域发展的尤为迅速,当下我们可以借助许多成熟的跨端框架,通过自己擅长的开发方式进行多端应用的实现,提升效率的同时,也让更多个体开发者可以方便快捷的实现自己的想法,在此向这些开源的跨端框架致敬。


通过两个多月的开发,整体体验下来对框架由陌生到熟悉,中间遇到了非常多的坑,也走到了几个死胡同,学到很多,而这些不亲身实践是很难想到的和体会到的。


而这两个多月里,整体的创意设计、架构设计、APP逻辑开发、后端开发的占用实践比例大致是1:1:3:1,相信如果重头再来开发的话,APP逻辑开发的耗时占比将于后端开发差不多。


感谢跨端框架,助力我实现APP自由。


过程中如果有更多需要交流的,欢迎留言评论或者发邮件给我,我的邮箱swmabby@gmail.com

目录
相关文章
|
4天前
|
运维 监控 API
后端开发中的微服务架构:优势与挑战
【8月更文挑战第16天】在软件开发的世界中,微服务架构已经成为一种流行和强大的设计模式。它通过将应用程序分解为一组小型、独立的服务来促进敏捷开发和快速迭代。本文旨在深入探讨微服务架构的核心优势以及实施过程中可能遇到的挑战,帮助读者更好地理解这一现代软件设计方法。
|
3天前
|
Web App开发 Android开发
FFmpeg开发笔记(四十六)利用SRT协议构建手机APP的直播Demo
实时数据传输在互联网中至关重要,不仅支持即时通讯如QQ、微信的文字与图片传输,还包括音视频通信。一对一通信常采用WebRTC技术,如《Android Studio开发实战》中的App集成示例;而一对多的在线直播则需部署独立的流媒体服务器,使用如SRT等协议。SRT因其优越的直播质量正逐渐成为主流。本文档概述了SRT协议的使用,包括通过OBS Studio和SRT Streamer进行SRT直播推流的方法,并展示了推流与拉流的成功实例。更多细节参见《FFmpeg开发实战》一书。
14 1
FFmpeg开发笔记(四十六)利用SRT协议构建手机APP的直播Demo
|
2天前
|
存储 监控 安全
后端开发中的API设计艺术
【8月更文挑战第18天】在数字时代的浪潮中,后端开发作为技术架构的基石,其重要性不言而喻。API设计,作为后端开发的关键环节,直接影响着软件系统的性能、可维护性及用户体验。本文将深入探讨API设计的基本原则、常见挑战及其应对策略,旨在为读者提供一套系统的API设计方法论,帮助开发者构建更加高效、稳定且易于扩展的后端服务。通过分析API设计的核心要素,我们将揭示如何打造优雅且强大的后端API,确保它们能够支撑起现代应用的复杂需求。
12 5
|
1天前
|
前端开发 IDE Java
"揭秘前端转Java的秘径:SpringBoot Web极速入门,掌握分层解耦艺术,让你的后端代码飞起来,你敢来挑战吗?"
【8月更文挑战第19天】面向前端开发者介绍Spring Boot后端开发,通过简化Spring应用搭建,快速实现Web应用。本文以创建“Hello World”应用为例,展示项目基本结构与运行方式。进而深入探讨三层架构(Controller、Service、DAO)下的分层解耦概念,通过员工信息管理示例,演示各层如何协作及依赖注入的使用,以此提升代码灵活性与可维护性。
|
1天前
|
人工智能 物联网 持续交付
后端开发的未来趋势与挑战
【8月更文挑战第19天】随着技术的不断进步,后端开发领域正面临着前所未有的变革。从云计算的普及到人工智能的崛起,再到物联网的发展,这些技术趋势不仅为后端开发带来了新的机遇,也带来了诸多挑战。本文将深入探讨这些趋势如何影响后端开发,并预测未来的发展方向。
|
2天前
|
NoSQL Java 关系型数据库
探索后端开发:从新手到专家的旅程
【8月更文挑战第18天】 在数字时代的浪潮中,后端开发作为技术架构的核心,承载着数据处理和逻辑运算的重任。本文将引导你理解后端开发的精髓,从基础概念出发,逐步深入到高级应用,最终掌握如何打造高效、稳定的后端系统。我们将一起探讨语言选择、框架应用、数据库管理、API设计以及安全性考量等关键要素,为你的后端开发之路提供一份清晰的指南。
9 3
|
1天前
|
消息中间件 NoSQL 持续交付
构建高效微服务架构:后端开发的新范式
【7月更文挑战第50天】在数字化转型的浪潮中,微服务架构已成为推动企业敏捷开发和维护的关键。本文深入探讨了如何构建一个高效的微服务架构,包括选择合适的技术栈、确保服务的可伸缩性与弹性、以及实现持续集成和持续部署(CI/CD)。通过分析具体案例,文章揭示了后端开发者如何在不断变化的技术环境中保持竞争力,并提出了优化策略以提升系统整体性能和可靠性。
|
1天前
|
缓存 前端开发 JavaScript
高效开发现代 Web 应用:从前端到后端的最佳实践
在开发现代 Web 应用时,前端和后端技术的选择对项目的性能、可维护性和用户体验至关重要。本文将探讨如何通过现代工具和框架来优化前端和后端开发流程。我们将分析前端技术(如 React 和 Vue.js)与后端技术(如 Node.js 和 Django)的集成,并提供实际案例来展示如何实现高效开发。无论是对新手还是经验丰富的开发者,本指南都提供了宝贵的洞见和实用的技巧,以帮助提高开发效率并构建出色的 Web 应用。
|
5天前
|
前端开发 Java C++
超简单使用Vite+Vue3构建共享开发和分模块打包的前端项目
使用Vite和Vue3构建支持共享组件和分模块独立打包的前端项目的方法。
9 0
超简单使用Vite+Vue3构建共享开发和分模块打包的前端项目
|
5天前
|
存储 前端开发 JavaScript
Springboot+Vue实现将图片和表单一起提交到后端,同时将图片地址保存到数据库、再次将存储的图片展示到前端vue页面
本文介绍了使用Springboot后端和Vue前端实现图片与表单数据一起提交到后端,并保存图片地址到数据库,然后展示存储的图片到前端Vue页面的完整流程。
Springboot+Vue实现将图片和表单一起提交到后端,同时将图片地址保存到数据库、再次将存储的图片展示到前端vue页面

热门文章

最新文章