「Flask入门」在index.html中显示md

首先要在云服务器上下载 marked 插件,命令如下,

npm install marked
npm install @types/marked # For TypeScript projects

也可以访问它的 github官网 一探究竟。之后,就可以在 index.html 中添加 .ajax 功能代码了,

<body>
  <script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
  <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>
  <script>
    $(function(){
      $.ajax({
        type:"get",
        url:"/testmd",
        dataType:"html",
        success:function(res){
          parsemd(res)
        }
      })

      function parsemd(data) {
        document.getElementById('content').innerHTML = marked.parse(data);
      }
    })
  </script>
</body>

其中的第 4、5 两行是引入必要的 CDN,紧随其后的第 6~21 行是异步获取 .md 的功能函数。其中的 url 属性最为重要,它即是后端的路由。在 hello.py 中注册路由,

@app.route('/testmd', methods=['GET'])
def test_md():
  try:
    return send_from_directory(directory='static/md/', path='test.md')
  except Exception as e:
    return str(e) 

流程是这样的,index.html 的 .ajax 根据 url 去 .py 中寻找对应路径的注册函数,并进行调用。找到 test_md() 后,其调用 send_from_directory() 将 test.md 内容返回给 .ajax。其中,test.md 在自建的 static/md/ 目录下

.ajax 收到后通过 parsemd() 函数解析传来的文本内容,并将其渲染在 content 上

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值