Flutter Web网站之Markdown展示与博客列表

简介: Flutter Web网站之Markdown展示与博客列表

往期


上期回顾


上期主要实现了主题切换,通过StreamBuilder来动态的切换ThemeData,最终达到效果。

本期内容


  • Markdown文本展示
  • 博客列表实现

UI 效果


image.png

image.png

image.png

image.png

两种主题展示效果

  • 示例  提供简单的使用案例,帮助你初步了解该框架的使用方法
  • 博客  提供高质量的博客,通过博客的学习,能更好的掌握,并避免不必要的坑,博客分了左右两层,右边内容展示的博客推荐位,推荐比较厉害的博主,希望你喜欢,目前该功能策划中,预计之后的版本会完善逻辑

示例代码实现


class Demos extends StatelessWidget {
  final String markDownData ;
  const Demos({Key key, this.markDownData}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    return Container(
      child: Markdown(
          data: markDownData??markdownData,
          selectable: true,
          imageDirectory: 'https://raw.githubusercontent.com'),
    );
  }
}

这里引入了一个框架flutter_markdownflutter_markdown是flutter版本解析Markdown文本的框架Markdown是一种轻量级标记语言,它允许人们使用易读易写的纯文本格式编写文档,如果你还对Markdown不熟悉,如果你喜欢写东西,建议学一学,点击上面Markdown即可开始学习。

flutter_markdown: ^0.3.5

有了Markdown框架我们就很简单的展示代码的示例了。

博客代码实现


class Blogs extends StatelessWidget {
  final List<Components> componentsList;
  const Blogs({Key key, this.componentsList}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    return Row(
      children: <Widget>[
        Expanded(
          flex: 2,
          child: Column(
            children: <Widget>[
              heightBoxBig,
              Expanded(
                child: ListView.builder(
                    shrinkWrap: true,
                    itemCount: componentsList.length,
                    itemBuilder: (context, index) {
                      Components components = componentsList[index];
                      return Card(
                        child: ListTile(
                          onTap: () {
                            launch(components.url);
                          },
                          title: textCardTitle(components.title),
                          subtitle: textCardSubTitle(components.subTitle),
                          leading: Image.asset(components.leading),
                        ),
                      );
                    }),
              ),
            ],
          ),
        ),
        ResponsiveWidget.isLargeScreen(context)
            ? Expanded(
                flex: 1,
                child: Column(
                  children: <Widget>[
                    heightBoxBig,
                    Card(
                      child: Image.asset(blogger),
                    )
                  ],
                ),
              )
            : Container()
      ],
    );
  }
}

用Row将页面横向排列,用Expanded将页面三等分,左边占三分之二,用ListView.builder动态构建列表容器,并用Card+ ListTile展示卡片式的布局,ListTile设置左头像leading,主标题title,子标题subtitle,并添加点击事件onTap,实现博客url的跳转。

源码


请转github代码查看完整实现

ToDo


该部分内容后期慢慢给大家更新,请客观不要着急,当然你可以参与进来,私聊我就行哦。

  • 示例部准备下期实现,跳转至详情页面,并展示用例。源码已经完成点击即可跳转至github。
  • 博客,这里考虑到有很多优秀的大佬,写过相关技术博客,帮你寻找最优秀的资源。功能设计如下图新增按钮。
  • Tags 部分下期实现,这部分也需要新的UI展现,标签的功能类似与搜索,提供更快捷的方式查找想要的功能。
  • 留言功能设计,在你们使用过程中肯定会有不同的建议,有了这个功能就能知道你们的心声,所以这也是我们需要的实现的一个功能。
  • 优秀的项目推荐,有很多优秀的项目等待着我们去发现,我一个人的能力有限,如果有更多的人来推荐,会不断丰富我们的Jetpack内容。

image.png

  • 源码部分目前是跳转至github,下期做下跳整,源码将展示对该框架的源码分析,标题部分将承载跳转至github的责任
  • 示例部分,博客部分不断的加入新的进来
  • 博客部分新增自我推荐入口,来收集你认为的对该框架解释的好文章

结束


网站jetpack.net.cn,欢迎常来,也希望能在你学习Flutter的道路上提供一丢丢的帮助。


目录
相关文章
|
16天前
|
前端开发 搜索推荐 JavaScript
Web前端网站(二)- 主页
页面星空是可动的哦~~~毒药水特效的颜色搭配,文字渐变的动态效果,图片360度旋转展示特效等等等;每一次的按钮点击都是满满的惊艳 ~ ~ ~
26 4
Web前端网站(二)- 主页
|
16天前
|
存储 前端开发 搜索推荐
Web前端网站(一) - 登录页面及账号密码验证
页面背景动态是烟花和文字特效与缓缓下落的雪花相结合,在登录表单的旁边还有五个白色光圈以不规则的方式环绕,当鼠标靠近时,会发出彩色的光芒~~~
29 1
Web前端网站(一) - 登录页面及账号密码验证
|
9天前
|
监控 Serverless 持续交付
阿里云云效产品使用问题之如何让流水线支持构建 flutter web 应用到 OSS
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
15天前
|
存储 Apache 文件存储
在Apache环境下为Web网站增设访问控制:实战指南
在Apache服务器上保护网站资源涉及启用访问控制模块(`mod_authz_core`和`mod_auth_basic`),在`.htaccess`或`httpd.conf`中设定权限,如限制对特定目录的访问。创建`.htpasswd`文件存储用户名和密码,并使用`htpasswd`工具管理用户。完成配置后重启Apache服务,访问受限目录时需提供有效的用户名和密码。对于高安全性需求,可考虑更复杂的认证方法。【6月更文挑战第20天】
70 4
|
15天前
|
安全 Ubuntu 应用服务中间件
NGINX环境下实现Web网站访问控制的实战指南
在NGINX中设置基于IP的访问控制可提升网站安全性。步骤包括安装NGINX、备份配置文件、编辑`/etc/nginx/sites-available/default`,添加`allow`和`deny`指令限制特定IP访问,如`allow 192.168.1.100; deny all;`,然后测试配置并重启服务。成功后,仅允许的IP能访问网站,否则会收到403错误。这为Web安全提供基础保障,还可扩展实现更多高级控制策略。【6月更文挑战第20天】
79 3
|
26天前
|
数据库 数据安全/隐私保护 Python
Web实战丨基于django+html+css+js的电子商务网站
Web实战丨基于django+html+css+js的电子商务网站
42 3
|
26天前
|
前端开发 安全 数据安全/隐私保护
Web实战丨基于django+html+css+js的在线博客网站
Web实战丨基于django+html+css+js的在线博客网站
30 2
|
4天前
|
机器人 开发工具 Android开发
flutter web 优化和flutter_admin_template
flutter web 优化和flutter_admin_template
|
4天前
Flutter 列表学习(listview,gridview,ExpansionTile,ScrollController,RefreshIndicator)
Flutter 列表学习(listview,gridview,ExpansionTile,ScrollController,RefreshIndicator)
|
18天前
|
移动开发 小程序 安全
基础入门-APP架构&小程序&H5+Vue语言&Web封装&原生开发&Flutter
基础入门-APP架构&小程序&H5+Vue语言&Web封装&原生开发&Flutter