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(),

],

),

复制代码
* 每次点击热重载时我们发现单词都不相同,成功实现。
相关推荐
江上清风山间明月1 小时前
一周掌握Flutter开发--9. 与原生交互(下)
flutter·交互·原生·methodchannel
GeniuswongAir1 小时前
Flutter极速接入IM聊天功能并支持鸿蒙
flutter·华为·harmonyos
sayen1 小时前
记录 flutter 文本内容展示过长优化
前端·flutter
勤劳打代码1 小时前
剑拔弩张——焦点竞争引的发输入失效
flutter·客户端·设计
张风捷特烈5 小时前
Flutter 伪 3D 绘制#02 | 地平面与透视
android·flutter
关山月6 小时前
Flutter 图像上传与裁剪
flutter
陈朝晖SHS6 小时前
Flutter求助贴
flutter
恋猫de小郭7 小时前
Flutter Roadmap 2025 发布,快来看看有什么更新吧
android·前端·flutter
陈皮话梅糖@11 小时前
使用 Provider 和 GetX 实现 Flutter 局部刷新的几个示例
开发语言·javascript·flutter
小墙程序员18 小时前
Flutter 教程(十)主题
flutter