🔧 なぜMVVMを使うのか?
Android開発では、UIとロジックが密結合になりやすいため、規模が大きくなると保守が難しくなります。
MVVMは以下のような悩みを解消します:
- ActivityやFragmentが肥大化する(God Class)
- テストしづらい
- 再利用性が低い
🧱 MVVMの3つの要素
要素 | 説明 |
---|---|
Model | データやビジネスロジック。たとえば、DBアクセスやAPI通信など。 |
View | UI(ActivityやFragment)。基本的にユーザーへの表示と操作の受け付けを担当。 |
ViewModel | UI向けのデータ保持&変換。Modelからデータを取得し、Viewに渡す中間役。UIのロジックもここに集約。 |
📦 構成のイメージ(図)
[ View (Activity / Fragment) ]
↑ ↕
DataBinding |
↓ |
[ ViewModel (UI状態・処理) ]
↓
[ Model (DB/APIなど) ]
✅ サンプル:TODOリスト風の簡易構成
Model層(データ取得)
public class TaskRepository {
public List<String> getTasks() {
return Arrays.asList("買い物", "宿題", "読書");
}
}
ViewModel層
public class TaskViewModel extends ViewModel {
private final MutableLiveData<List<String>> tasks = new MutableLiveData<>();
private final TaskRepository repository = new TaskRepository();
public LiveData<List<String>> getTasks() {
return tasks;
}
public void loadTasks() {
tasks.setValue(repository.getTasks());
}
}
View層(Activity)
public class MainActivity extends AppCompatActivity {
private TaskViewModel viewModel;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ActivityMainBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
viewModel = new ViewModelProvider(this).get(TaskViewModel.class);
binding.setViewModel(viewModel);
binding.setLifecycleOwner(this);
viewModel.loadTasks(); // データ読み込み
}
}
XML(activity_main.xml
)
<layout xmlns:android="http://schemas.android.com/apk/res/android">
<data>
<variable name="viewModel" type="com.example.TaskViewModel"/>
</data>
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text='@{viewModel.tasks[0]}' />
</LinearLayout>
</layout>
🎯 MVVMで意識すべきポイント
- ViewModelにUIの状態とロジックを集約
- Modelは外部との接点(DB, API)に集中
- Viewはできるだけ表示だけに徹する
📝 補足:JavaでMVVMを書く場合の注意点
- DataBindingはKotlinと比べるとJavaではやや冗長になりがちですが、十分実用的です。
LiveData
を使えば、状態の監視が簡単になります(コールバック地獄から脱出)。ViewModelProvider
で ViewModel を適切にスコープ管理しましょう。