Qt+Cutelyst学习笔记(十二)win10 + Qt5.15.2 使用视图和模板

前言:

上一篇编译好了grantlee视图插件,本篇记录下这个插件的测试过程

一、创建CUTELYST项目

找一个空白目录,注意不能有中文或空格,执行如下命令

#windows下执行
cutelyst3-qt5.exe --create-app hello

#linux下执行
cutelyst3-qt5 --create-app hello

二、修改源码并编译

使用QtCreator打开并配置工程,

1.修改src/CMakeLists.txt工程

target_link_libraries(Hello
    ...
    Cutelyst::View::Grantlee # Add this line
    ...
}

2.创建Grantlee视图

修改src/hello.cpp

...
#include <Cutelyst/Plugins/View/Grantlee/grantleeview.h>
...
bool Hello::init()
{
    ...
    new GrantleeView(this);
    ...
}

在src/root.h中,加入如下公有函数

C_ATTR(hello, :Global)
void hello(Context *c);

在src/root.cpp中,添加实现

void Root::hello(Context *c)
{
    c->setStash("template", "hello.html");
}

添加完成后,直接编译,可以得到生成的动态库

windows下是hello.dll

linux下是libhello.so

二、运行新的动态库

创建一个root/hello.html模板文件。以下是一个简单的示例:


<p>
    This is a Grantlee view template, called '{{ template }}'.
</p>

设置好环境变量,执行如下命令

#windows下执行
cutelyst3-qt5.exe --server --app-file src/hello -- --chdir ..

#linux下执行
cutelyst3-qt5 -r --server --app-file src/hello -- --chdir ..


#--app-file 后的参数是应用程序(dll库)的位置,请读者自行修改
#注:可以省略dll扩展名

注:可以省略应用程序后缀,如.so, .dll, .dylib,因为它会自动查找带有适当后缀的文件。

注:--chdir 后面的参数,是root所在的目录,使用影子编译的小伙伴要注意下,一定要放对参数

运行后,打开本地浏览器,输入 http://localhost:3000/hello,显示如下

 命令行输出如下

 至此,本次测试完成

 本次测试示例源码下载

后记

笔者对这个模板没什么研究,若是有时间,会研究下,下一篇继续探究

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

꧁白杨树下꧂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值