Android进阶之路Flutter让前端飞

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

2020-05-13  本文已影响0人  i校长

往期

上期回顾

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

本期内容

UI 效果





两种主题展示效果

示例代码实现

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_markdown
flutter_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

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

结束

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

上一篇下一篇

猜你喜欢

热点阅读