Flutter包管理(三)

1、作用

在APP的实际开发过程中往往会依赖很多包,而这些包之间存在着交叉依赖、版本依赖,由开发者自己管理手动管理会非常麻烦,每种开发生态或编程官方会提供一些包的管理工具,在Flutter中我们在pubspec.yaml文件中来管理第三方依赖包。

2、配置文件解释

dart 复制代码
name: flutter_learn
    
description: "A new Flutter project."

publish_to: 'none'

version: 1.0.0+1

environment:
  sdk: ^3.5.3


dependencies:
  flutter:
    sdk: flutter

  cupertino_icons: ^1.0.8

dev_dependencies:
  flutter_test:
    sdk: flutter

  flutter_lints: ^4.0.0

flutter:

  uses-material-design: true
  • name:应用或包的名称;
  • description:应用或包的描述、简介;
  • publish_to:是否将包发布到公共存储库,none代表包不会被发布;
  • version:应用或包的版本号;
  • environment:运行此项目所需的环境要求;
  • dev_dependencies:项目运行时所依赖的包;
  • flutter:Flutter相关配置。

4、Pub仓库

我们可以在pub仓库中查找需要的包和插件,也可以发布包和插件,接下来将使用其中的english_words实现随机字符串的Widget。

4.1 将english_words添加到依赖项列表

搜索english_words,我们发现最新版本是v 4.0.0,那我们就将该版本加入到依赖项列表。

dart 复制代码
dependencies:
  flutter:
    sdk: flutter


  cupertino_icons: ^1.0.8
  english_words: ^4.0.0 # 添加的依赖项
4.2 安装依赖包
4.3 导入包
dart 复制代码
import 'package:english_words/english_words.dart';
4.4 创建Wiget
dart 复制代码
// 随机生成字符串
class RandomWordsWiget extends StatelessWidget {
  const RandomWordsWiget({super.key});

  @override
  Widget build(BuildContext context) {
    // 生成随机字符串
    final word = WordPair.random();
    return Padding(
      padding: const EdgeInsets.all(8.0),
      child: Text(word.toString()),
    );
  }
}
  • 在_MyHomePageState.build的Column的字类Wiget中添加RandomWordsWiget。
dart 复制代码
child: Column(
  mainAxisAlignment: MainAxisAlignment.center,
  children: <Widget>[
    // 省略无关代码...
    const RandomWordsWiget(),
  ],
),

Alignment.center,

children: [

// 省略无关代码...

const RandomWordsWiget(),

],

),

复制代码
* 每次点击热重载时我们发现单词都不相同,成功实现。
相关推荐
BigPomme2 小时前
Flutter 3.29.0 使用RepaintBoundary或者ScreenshotController出现导出图片渲染上下颠倒问题
flutter
Pedro3 小时前
Flutter - 多版本管理工具FVM
flutter
未来猫咪花3 小时前
保持 Widget.build 内部的纯净
flutter·dart
初遇你时动了情20 小时前
uniapp/flutter中实现苹果IOS 26 毛玻璃效果、跟随滑动放大动画
flutter·ios·uni-app
listhi5201 天前
Vue.js 3的组合式API
android·vue.js·flutter
起风了___1 天前
Flutter 多端音频控制台:基于 audio_service 实现 iOS、Android 锁屏与通知中心播放控制
前端·flutter
leinchu1 天前
Flutter + Codebuddy的坑
flutter
安卓开发者1 天前
第4讲:理解Flutter的灵魂 - “Everything is a Widget”
开发语言·javascript·flutter
起风了___1 天前
Flutter 全局音频播放单例实现(附完整源码)——基于 just_audio 的零依赖方案
前端·flutter
DreamMachine1 天前
Flutter 开发的极简风格音乐播放器
前端·flutter