Flutter生成人类可读ID插件human_readable_ids的使用

Flutter生成人类可读ID插件human_readable_ids的使用

在本指南中,我们将探讨如何在Flutter项目中使用human_readable_ids插件来生成人类可读的ID。此插件允许你从名词和形容词列表中生成格式为形容词-名词-数字的ID。

特性

生成的ID格式如下:

  • silly-goose-37
  • quick-cobra-15
  • tricky-chicken-23
  • brave-ladybug-90

当前ID空间大约有1,000,000个ID(100个形容词 * 100个名词 * 100个整数范围)。

使用方法

首先,你需要在你的pubspec.yaml文件中添加human_readable_ids依赖项:

dependencies:
  human_readable_ids: ^1.0.0

然后,你可以使用以下代码来生成人类可读的ID:

import 'package:human_readable_ids/human_readable_ids.dart';

void main() {
  print("id: ${humanReadableId()}");
}

完整示例

下面是一个完整的示例,展示了如何使用human_readable_ids插件生成人类可读的ID:

import 'package:human_readable_ids/human_readable_ids.dart';

void main() async {
  /// 简写方式
  print('id: ${humanReadableId()}');

  /// 长版本
  var generator = HumanReadableIdGenerator();
  print('id: ${generator.generate()}');
  print('id: ${generator.generate()}');

  /// 自定义生成器
  var stupidGenerator = HumanReadableIdGenerator(
    numericIdsRange: 1,
    nouns: ["john"],
    adjectives: ['genius'],
  );

  print('id: ${stupidGenerator.generate()}');
  assert(stupidGenerator.generate() == stupidGenerator.generate());
}

运行示例

运行上述代码后,你将看到类似以下输出:

id: silly-goose-37
id: quick-cobra-15
id: tricky-chicken-23
id: brave-ladybug-90
id: john-genius-0

通过自定义生成器,你可以控制生成的ID的形容词、名词和数字范围,从而满足特定需求。

更多示例可以在/example文件夹中找到。


更多关于Flutter生成人类可读ID插件human_readable_ids的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter生成人类可读ID插件human_readable_ids的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,以下是如何在Flutter项目中使用human_readable_ids插件生成人类可读ID的示例代码。这个插件允许你生成短且易于阅读的唯一ID,非常适合在用户界面上显示。

首先,确保你已经在pubspec.yaml文件中添加了human_readable_ids依赖:

dependencies:
  flutter:
    sdk: flutter
  human_readable_ids: ^latest_version # 请替换为实际的最新版本号

然后,运行flutter pub get来安装依赖。

接下来,在你的Flutter应用中,你可以按照以下步骤使用human_readable_ids插件:

  1. 导入插件

在你的Dart文件中导入human_readable_ids插件:

import 'package:human_readable_ids/human_readable_ids.dart';
  1. 生成人类可读ID

使用HumanReadableIds类的generate方法来生成一个ID。你可以指定ID的长度和字符集。以下是一个简单的示例:

void main() {
  // 初始化HumanReadableIds实例
  final humanReadableIds = HumanReadableIds();

  // 生成一个长度为8的ID,使用默认字符集
  String id = humanReadableIds.generate(length: 8);

  print('Generated ID: $id');
}
  1. 在Flutter Widget中使用

你可以将这个ID生成逻辑放入一个Flutter Widget中,例如一个按钮点击事件:

import 'package:flutter/material.dart';
import 'package:human_readable_ids/human_readable_ids.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Human Readable IDs Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  String? generatedId;

  void _generateId() {
    final humanReadableIds = HumanReadableIds();
    setState(() {
      generatedId = humanReadableIds.generate(length: 8);
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Human Readable IDs Demo'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              generatedId ?? 'Press the button to generate an ID',
              style: TextStyle(fontSize: 24),
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: _generateId,
              child: Text('Generate ID'),
            ),
          ],
        ),
      ),
    );
  }
}

在这个示例中,当你点击“Generate ID”按钮时,会生成一个新的长度为8的人类可读ID,并在屏幕上显示。

这个示例展示了如何在Flutter应用中使用human_readable_ids插件来生成人类可读ID,并将其显示在UI上。根据你的具体需求,你可以调整ID的长度和字符集。

回到顶部