从零开始搭建一个项目框架MVVM(OC)

1.新建一个项目输入你的ProductName(项目名称)、组织、开发者账号等一些简单的选项


2.配置开发环境



3.修改个人配置





4.创建cocoaPod依赖库

4.1:cd 项目
4.2:创建PodFile(touch PodFile)
4.3:编辑PodFile(vim PodFile)



4.4 输入’i’开始编辑 按住ESC 输入’:wq’保存退出,然后创建pod对应的target(pod install)

4.5:生成了个workSpace,双击打开就是了


4.5创建git仓库(可以不用)


使用加密证书保存登录信息--创建SSH文件(根据git说明即可)


4.6创建远程仓库(假设使用Coding)


4.7将远程项目clone到本地

4.8将你的项目copy到这里,然后推动到远程
git add .添加全部文件到缓存
git commit -m “提交版本说明” 创建一个提交版本,暂存于本地
git push origin master 推送到远程,这样一个基本项目git仓库就完成了

5.项目基本结构




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为你介绍一个简单的MVVM请求框架实现。 首先,我们需要一个网络请求库,这里我们可以使用 Retrofit。在ViewModel中发起网络请求,获取数据并在View中展示。 下面是一个简单的实现步骤: 1. 创建一个ApiService接口,用于定义网络请求的接口方法。 ```java public interface ApiService { @GET("api/data/{category}/{count}/{page}") Call<GankResponse> getGankData(@Path("category") String category, @Path("count") int count, @Path("page") int page); } ``` 2. 创建一个Retrofit实例,并创建一个ApiService的实例。 ```java private static final String BASE_URL = "http://gank.io/"; private Retrofit retrofit; private ApiService apiService; public RequestViewModel() { retrofit = new Retrofit.Builder() .baseUrl(BASE_URL) .addConverterFactory(GsonConverterFactory.create()) .build(); apiService = retrofit.create(ApiService.class); } ``` 3. 在ViewModel中定义一个请求方法,使用Retrofit发起网络请求。 ```java public void getGankData(String category, int count, int page) { apiService.getGankData(category, count, page).enqueue(new Callback<GankResponse>() { @Override public void onResponse(Call<GankResponse> call, Response<GankResponse> response) { if (response.isSuccessful()) { GankResponse result = response.body(); // 数据获取成功,更新LiveData data.setValue(result.getResults()); } else { // 数据获取失败,更新LiveData data.setValue(null); } } @Override public void onFailure(Call<GankResponse> call, Throwable t) { // 数据获取失败,更新LiveData data.setValue(null); } }); } ``` 4. 在View中观察ViewModel中的LiveData,并在数据发生改变时更新UI。 ```java requestViewModel = ViewModelProviders.of(this).get(RequestViewModel.class); requestViewModel.getData().observe(this, new Observer<List<GankData>>() { @Override public void onChanged(List<GankData> gankData) { if (gankData != null) { // 数据获取成功,更新UI adapter.setData(gankData); } else { // 数据获取失败,提示用户 Toast.makeText(MainActivity.this, "数据获取失败", Toast.LENGTH_SHORT).show(); } } }); ``` 以上就是一个简单的MVVM请求框架的实现。其中,ViewModel负责处理数据,LiveData负责向View传递数据变化,View则负责展示数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值