写给Android开发者看的『微信小程序和Android开发的对比』

写给Android开发者看的『微信小程序和Android开发的对比』,第1张

微信小程序近期可谓是动作频出,仅最近新增的能力就有:

种种迹象表明,微信对小程序的期望值是很大,所以在它推出的几个月效果没到达预期的情况下,之前的很多『克制』也就逐渐变成『放肆』了 —— 不过不管小程序以后的发展到底怎样,对我们开发者来发,多了解一些总是没有坏处的。

他山之石,可以攻玉。

对于是技术人来说,多了解一些不同的技术、不同的开发模式、不同的架构思想,提高技术『广度』,对于自己的成长是十分必要的。

所以,本文就是从一个 Android 开发者的角度,从项目工程方便切入,来分析一下『微信小程序』跟『Android App』开发上的一些异同。

『微信小程序』开发是一个相对较新的技术,希望通过本文,能让你对它多一些了解。

因为内容是从Android开发的角度来谈的,所以我假设你已经对 Android 开发比较熟悉了。并且对微信小程序的开发也比较感兴趣,如果要是再能有些 javascript、css 的基础的话那就更好了!

Android 开发我们已经比较熟悉——

作为对比,进行微信小程序开发所用的语言是这些——

wxml (WeiXin Markup Language) 基本约等于是 xml。微信之所以没有直接使用 xml ,可能是为了以后扩展方便一些(野心很大)。

同理, wxss (WeiXin Style Sheets) 基本约等于是 css。也是微信扩展了一些功能,比如统一的尺寸单位 rpx 。

对于 Android 来说,对于页面的描述基本上在 xml 中定义的,比如:

这是一个简单的典型的示例,这个文件就是描述了两部分内容:

somewxss:

很明显可以看出:wxml 是负责了 页面结构 的展示;而 wxss 则负责了对 页面样式 的定义。

这种把结构和样式分离的做法,其实是延续了网页开发中的习惯(html + css)。

这样做的好处起码有两个:

——看起来还是挺简单的结构:

这三个文件用以描述小程序 app 相关的内容,他们的命名是固定这样的,位置也固定是在根目录下。

appjs 基本相当于 Android 中的 Application 类,文件中主要是有一个 App() 函数,来进行小程序的初始化 *** 作。

appjson 的作用跟 Android 中的 AndroidMainifestxml 文件很相似 —— 都是静态化的配置文件。

appwxss 定义全局的样式 —— 其定义的样式会作用于每个页面。比如在 appwxss 中加入:

就可以给所有的 text 控件添加 5px 的 padding 。

当然,页面本身的 xxPagewxss 可以定义局部样式来覆盖全局样式。

根目录下的 utils 文件夹中有一个 utiljs 文件,这个故名思意,是类似于 Java 中的一些工具类的存在。

utils 文件夹其实是一个非必须的结构,而它之所以出现在官方的 HelloWorld 工程中,是作为一个代表,表明了开发者在这里是可以自定义新的文件夹和结构的。微信小程序作为一个使用 js 来开发的平台,是可以使用许多第三方的 js 库的,对于这些第三方库,以及其他的资源等,都可以放到自定义的文件夹中。

pages 文件夹下包含两个子目录:index 和 logs ,两个目录的结构都是基本一样的,都是包含四个相同主名称的文件: xxjs、xxwxml、xxjson、xxwxss 这几个文件。

这样的一个典型结构表明它是一个小程序的页面,四个文件的作用分别是:

在视图的动态显示上,微信小程序使用了 数据绑定(data-binding) 的方式。

如果你之前使用过 AngularJS 或者 Vuejs 等这些流行的 js 框架,那么你肯定对 数据绑定 并不陌生。它是一种把一个控件的属性绑定到某个数据对象(view-model)的属性的方法,这样在改变数据对象属性的时候,所对应的控件属性也就会相应变化 —— 在开发中,这种方式会使得对 View 层的显示控制变得十分简单、自然。

基于此,软件工程的流行架构方式也在之前的 MVC 、 MVP 之外,又多了一个 —— MVVM(Model-View-ViewModel) 。

数据绑定 这种方式现在是如此的流行,以致于 Android 官方都出了一个 [Data Binding Library] ( >

笔者由于工作需要,曾经参加过一个微信小程序同 SAP 系统集成的项目,因此从零开始学习了微信小程序的开发知识。这里通过系列文章把自己所学分享出来,希望对相关学习者有所帮助。

本教程前面三篇文章:

通过本系列前面三篇文章的介绍,大家对微信小程序的视图和控制器,微信调试器的用法,以及如何消费微信平台提供的 Public API,已经有了一个最基本的认识了。在这个基础上,本文让我们进一步学习微信小程序的页面跳转路由设计。

这个系列教程的前六篇文章我们都在单个的视图上 *** 作。现在让我们创建第二个视图,然后实现从第一个视图到第二个视图的跳转。

首先开发第二个视图:

做过 Angular 开发的朋友们对上面的视图设计一定不会陌生。这个视图的数据源由模型 logs 提供,是一个列表结果,列表每个元素的数据源是模型 logs 里的一条记录,用 log 代表。

为了让 log 看起来显示更整齐,在 log 内容之前,显示每条 log 的索引。因为 log 的索引从 0 开始,所以用 {{index + 1}} 在索引前加一,这样显示的索引更符合普通人的阅读习惯。

这个视图的控制器:

控制器 logsjs 的实现:

在控制器里调用 Page 构造函数,给当前控制器指定名为 logs 的数据模型。

这个数据模型的值填充,通过微信框架提供的 API wxgetStorageSync 来获取。

wxgetStorageSync 的含义在微信小程序 官网 上有定义:从本地缓存中同步获取指定 key 对应的内容。

第二个视图的 UI 和控制器都开发完毕,剩下的事情就是在第一个视图里定义一个触发点,让它能触发到第二个视图的跳转。

我在第一个视图上通过属性 bindtap 绑定了一个点击函数 bindViewTap :

bindViewTap 在第一个控制器 indexjs 里的实现:

跳转还是通过微信小程序提供的 API wxnavigateTo :

保留当前页面,跳转到应用内的某个页面,使用 wxnavigateBack 可以返回到原页面。

学习了微信小程序页面路由跳转之后,我们来进行一个实际的需求开发。

效果:我在手机上打开微信小程序,自动显示出我当前所在的地理位置:

具体步骤:

ReservationServicegetGeocode 的实现:

看下面一个使用高德地图 API 将经纬度转换成文字描述的地址的例子,使用 postman 发送请求:

API 响应:

假设我用 vue 开发了一个 web 应用,需要在手机微信里访问并调试, 可以按照本文介绍的步骤,使用微信开发者工具来调试。

假设我的 web 应用的访问入口是如下公众号菜单的"预约"按钮:

那么为了能够在微信开发者工具里调试,需要首先进入该公众号的后台,在 web 开发者工具里,将开发者本人的微信号添加进去:

点击"绑定开发者账号":

输入待绑定的微信账号:

点击绑定,该微信号会收到一条消息,询问是否绑定:

点击同意 *** 作完成绑定。

接下来, 把要调试的 web 应用的 url 放到微信开发者工具地址栏里,回车之后,微信开发者工具就会d出一个询问窗口,点击 Allow 之后,就可以在微信开发者工具提供的类似 Chrome 开发者工具调试器一样的界面里进行单步调试了。

这个粘贴到地址栏的 url 很有讲究。

>

你可以选择用即构科技的SDK来接入,它们家的IM SDK支持各平台互通,提供即时通讯示例源码,接入功能可靠、丰富的IM SDK在WEB和APP内快速实现聊天、发送文字、、语音、视频、文件,只需要30分钟, 就可以在app内集成 聊天和消息发送提升用户活跃学习了解下,

1、查看手机的所有进程:adb shell dumpsys activity top | findstr ACTIVITY

2、输入pid,查看具体进程:比如,adb shell ps 18951

3、一般微信小程序的进程就是:comtencentmm:appbrand0

4、在配置appium的时候一般就是需要配置上:

要看你的功能了

假设不需要中途总是查看这个倒计时,长达几天的话,可以调用日历,精确到天(也可以到小时分钟)之后,收到提醒再起service。由service启动你要启动的东西。

如果你中途要查看调整这个倒计时,那你只能用service。加些属性使它可以长存。如果关机,把时间写入到文件或者preference,开机再续计时,只有一些清理程序的软件能把这个service干掉。

activity主要用途是显示页面,不同于service,android系统喜欢对这类对象进行自动回收。如果你硬要它长存也可以的,设置属性能让它存在很长时间。但不建议使用。

android还有一类硬时钟,可以在关机状态下也依然计时,并且执行一些程序,你可以google一下。

环境搭建就不讲了,直接说开发。

闹钟程序开发中的要点就是:

1、时间选择对话框(TimePicker)

2、获取闹钟管理器并对其进行设置

3、注册广播接收器

掌握了这两点,写程序就很简单了。

1、新建android项目:Alarm,sdk版本选择22,Package name:comlqlactivity,Main Activity:Alarm

2、编写界面:直接修改layout中的mainxml文件,代码如下:

Xml代码

<xml version="10" encoding="utf-8">

<LinearLayout xmlns:android=">

android:orientation="vertical"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:gravity="center_vertical"

>

<Button

android:id="@+id/timeBtn"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="@string/time"

android:textSize="20sp"

/>

<Button

android:id="@+id/cancelAlarmBtn"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="@string/cancelAlarm"

/>

</LinearLayout>

界面的效果如下:

3、修改Alarmjava这个activity,在该Activity中需要做这样几件事:

获取界面上的两个按钮组件,并给其绑定事件监听器

第一个时间按钮,点击后,显示时间选择对话框(TimePicker),供选择小时和分钟,并设置闹钟

第二个按钮,点击之后需要当前设定的闹钟

比较难写的代码就是闹钟设置:

//设置时间

Java代码  

timeBtnsetOnClickListener(new ButtonOnClickListener(){

@Override

public void onClick(View arg0) {

Logd(TAG, "click the time button to set time");

calendarsetTimeInMillis(SystemcurrentTimeMillis());

new TimePickerDialog(Alarmthis,new TimePickerDialogOnTimeSetListener() {

@Override

public void onTimeSet(TimePicker arg0, int h, int m) {

//更新按钮上的时间

timeBtnsetText(formatTime(h,m));

//设置日历的时间,主要是让日历的年月日和当前同步

calendarsetTimeInMillis(SystemcurrentTimeMillis());

//设置日历的小时和分钟

calendarset(CalendarHOUR_OF_DAY, h);

calendarset(CalendarMINUTE, m);

//将秒和毫秒设置为0

calendarset(CalendarSECOND, 0);

calendarset(CalendarMILLISECOND, 0);

//建立Intent和PendingIntent来调用闹钟管理器

Intent intent = new Intent(Alarmthis,AlarmReceiverclass);

PendingIntent pendingIntent = PendingIntentgetBroadcast(Alarmthis, 0, intent, 0);

//获取闹钟管理器

AlarmManager alarmManager = (AlarmManager)getSystemService(ALARM_SERVICE);

//设置闹钟

alarmManagerset(AlarmManagerRTC_WAKEUP, calendargetTimeInMillis(), pendingIntent);

alarmManagersetRepeating(AlarmManagerRTC_WAKEUP, calendargetTimeInMillis(), 101000, pendingIntent);

ToastmakeText(Alarmthis, "设置闹钟的时间为:"+StringvalueOf(h)+":"+StringvalueOf(m), ToastLENGTH_SHORT)show();

Logd(TAG, "set the time to "+formatTime(h,m));

}

},calendarget(CalendarHOUR_OF_DAY),calendarget(CalendarMINUTE),true)show();

}

});

代码里面有注释,这里就不多解释了,其中new TimePickerDialog为创建时间选择对话框。为了能够看到效果,我给闹钟添加了重复提醒:alarmManagersetRepeating(AlarmManagerRTC_WAKEUP, calendargetTimeInMillis(), 101000, pendingIntent);。

还要为取消闹钟按钮添加事件监听器:

Java代码  

//取消闹钟按钮事件监听

final Button cancelAlarmBtn = (Button)findViewById(RidcancelAlarmBtn);

cancelAlarmBtnsetOnClickListener(new ButtonOnClickListener(){

@Override

public void onClick(View arg0) {

Intent intent = new Intent(Alarmthis,AlarmReceiverclass);

PendingIntent pendingIntent = PendingIntentgetBroadcast(Alarmthis, 0, intent, 0);

//获取闹钟管理器

AlarmManager alarmManager = (AlarmManager)getSystemService(ALARM_SERVICE);

alarmManagercancel(pendingIntent);

ToastmakeText(Alarmthis, "闹钟已经取消!", ToastLENGTH_SHORT)show();

}

});

在点击取消闹钟按钮时,取消之前设置的闹钟,核心代码就4行。

4、编写广播接收器,用来接收闹钟的广播事件,然后进行相关处理,

Java代码  

public class AlarmReceiver extends BroadcastReceiver {

/ (non-Javadoc)

 @see androidcontentBroadcastReceiver#onReceive(androidcontentContext, androidcontentIntent)

/

@Override

public void onReceive(Context arg0, Intent data) {

Logd(AlarmTAG, "the time is up,start the alarm");

ToastmakeText(arg0, "闹钟时间到了!", ToastLENGTH_SHORT)show();

}

}

这个代码就很简单了,主要是要继 承 BroadcastReceiver 这个类,然后重写onRecive方法。onRecive方法在闹钟的时间达到之后会执行,在这里我们可以做自己的事情,比如启动某个程序,或者播放铃声,我这里就是简单的提示一下,使用的是Toast。

5、在android的AndroidManifestxml文件中注册广播接收器:

<manifest xmlns:android=">

Xml代码

package="comqlactivity"

android:versionCode="1"

android:versionName="10">

<application android:icon="@drawable/icon" android:label="@string/app_name">

<receiver android:name="AlarmReceiver" android:process=":remote" />

<activity android:name="Alarm"

android:label="@string/app_name">

<intent-filter>

<action android:name="androidintentactionMAIN" />

<category android:name="androidintentcategoryLAUNCHER" />

</intent-filter>

</activity>

</application>

<uses-sdk android:minSdkVersion="8" />

</manifest>

核心的配置为<receiver android:name="AlarmReceiver" android:process=":remote" />,这也是闹钟程序的关键,如果不做这个配置,那么时间到了之后,闹钟将不会提示。

接下来就是到模拟器上测试,运行截图如上图。程序源代码见附件。

以上就是关于写给Android开发者看的『微信小程序和Android开发的对比』全部的内容,包括:写给Android开发者看的『微信小程序和Android开发的对比』、小程序学习笔记-百度统计、微信小程序开发系列 (四) :微信小程序的页面跳转路由设计等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zz/10215370.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-06
下一篇 2023-05-06

发表评论

登录后才能评论

评论列表(0条)

保存