Rust: 🚀 对话宏框架 dialoguer-macro 0.3 版本震撼发布

🚀 对话宏框架 dialoguer-macro 0.3 版本震撼发布:引领命令行交互设计新篇章

🎉 尊敬的开发者们,今天我怀着无比激动的心情向大家隆重推荐 dialoguer-macro 库的最新力作------0.3版本!这一版本的重大更新将彻底颠覆您对命令行用户交互设计的传统认知。我们已在新版本中倾情引入了对枚举类型和嵌套结构的强大支持,让您轻松构建出层次分明、结构优雅的命令行交互界面!

📚 文档教程直通车yexiyue.github.io/dialogue-ma...

🎯 实战演示开篇

在这篇博客中,我们将通过一个鲜活具体的实例来揭示如何运用 dialoguer-macro 0.3 中 SubAsker 属性及其关联的 AskerBuildEnumAsker 特质,打造一套高效且易用的命令行信息收集流程。

让我们一睹为快!

首先 ,定义了一个名为 UserInput 的结构体,并利用 #[derive(Asker)]#[asker(theme = "...")] 宏对其进行装饰,从而实现既美观又功能丰富的命令行输入界面。

值得注意的是,结构体中的 detailed_infoidentity 字段都应用了 #[asker(SubAsker)] 标记,这表示它们将以子询问器(SubAsker)的角色逐层深入地获取用户输入数据:

rust 复制代码
use dialogue_macro::{Asker, Build, EnumAsker};

#[derive(Debug, Asker)]
#[asker(theme = "dialogue_macro::ColorfulTheme")]
struct UserInput {
    // 基础信息字段
    username: String,
    educational_institution: String,

    // 使用 SubAsker 收集详细用户信息
    #[asker(SubAsker)]
    detailed_info: DetailedUserInfo,

    // 使用 SubAsker 进行身份选择
    #[asker(SubAsker)]
    identity: EnumSelection,
}

接下来,我们精心设计了两个用于嵌套询问的数据结构:

DetailedUserInfo 结构体 ,封装了用户的电子邮件地址和年龄属性。为了适应 SubAsker 的工作方式,此结构体不仅实现了 DebugCloneAsker 特性,还额外实现了 Build 特质,并在 impl Build for DetailedUserInfo 中定义了 .build() 方法,以便按序从用户那里获取邮箱地址和年龄:

rust 复制代码
#[derive(Debug, Clone, Asker)]
struct DetailedUserInfo {
    email_address: String,
    age: u8,
}

impl Build for DetailedUserInfo {
    fn build() -> Self {
        Self::asker()
            .email_address("请提供您的邮箱地址")
            .age("请输入您的年龄")
            .finish()
    }
}

EnumSelection 枚举 ,包含了 Teacher、Student 和 Leader 三个选项。该枚举除了实现了 DebugClone 特质外,还派生了 EnumAsker 特质,这意味着它能够以清晰直观的方式呈现在用户面前供其选择:

rust 复制代码
#[derive(Debug, EnumAsker, Clone)]
#[asker(prompt="请选择您的身份", default="Student")]
enum EnumSelection {
    Teacher,
    Student,
    Leader,
}

最后,在主函数中,我们创建并实例化了 UserInput 对象,并按照逻辑顺序依次调用各个字段对应的询问方法:

rust 复制代码
fn main() {
    let collected_user_input = UserInput::asker()
        .username("请输入用户名")
        .educational_institution("请输入您的学校名称")

        // 调用 SubAsker 收集详细的用户信息
        .detailed_info()

        // 调用另一个 SubAsker 让用户从枚举选项中做出选择
        .identity()

        // 收集所有用户输入并结束询问过程
        .finish();

    println!("{:?}", collected_user_input);
}

当运行程序时,用户会按照预设的层级顺序逐一回答问题,体验到一种既复杂又有条不紊的命令行交互之旅!

通过上述实例代码,我们展示了如何运用 SubAsker 等特性轻松实现层次分明的命令行交互设计。如果您对这个库的功能感到兴奋,并希望在您的项目中尝试这些创新功能,请立即前往我们的 GitHub 仓库地址:

👉 GitHub 项目主页github.com/yexiyue/dia...

在此,诚挚邀请您关注我的项目、尝试使用新版 dialoguer-macro,并参与到项目的成长中来。只需点击仓库页面上的 "Star" 按钮,即可给予我宝贵的肯定与支持。同时,我也热切期待您的反馈、贡献以及实际应用案例分享!

相关推荐
m0_7482402542 分钟前
前端如何检测用户登录状态是否过期
前端
black^sugar43 分钟前
纯前端实现更新检测
开发语言·前端·javascript
寻找沙漠的人1 小时前
前端知识补充—CSS
前端·css
GISer_Jing2 小时前
2025前端面试热门题目——计算机网络篇
前端·计算机网络·面试
m0_748245522 小时前
吉利前端、AI面试
前端·面试·职场和发展
理想不理想v2 小时前
webpack最基础的配置
前端·webpack·node.js
pubuzhixing2 小时前
开源白板新方案:Plait 同时支持 Angular 和 React 啦!
前端·开源·github
2401_857600952 小时前
SSM 与 Vue 共筑电脑测评系统:精准洞察电脑世界
前端·javascript·vue.js
2401_857600952 小时前
数字时代的医疗挂号变革:SSM+Vue 系统设计与实现之道
前端·javascript·vue.js
GDAL2 小时前
vue入门教程:组件透传 Attributes
前端·javascript·vue.js