这个web框架,你先要的他都有!

简介: 这个web框架,你先要的他都有!

前言


关于Api开发框架,我们已经介绍了不少,FastApiHUGBottle等等。今天我们就一起继续了解一款新的Api开发框架Emmett。


关于Emmett


Emmett是一款集成度高、可以让开发者专注于产品而不用关注太多底层东西的框架。其支持Socket、异步、内置ORM且可以简单的进行模型关联、聚合查询更容易、拥有全新易用的模板引擎,一切的一切只为方便开发者。


总结一下


  1. 简单的路由系统
  2. 集成ORM
  3. 优雅的验证引擎
  4. 安全的认证系统
  5. 方便的表单生成
  6. 内置国际化引擎
  7. 友好的模板引擎


快速开始


1、安装


pip install emmett
复制代码


2、创建项目


# 创建文件夹
mkdir emmett & cd emmett
# 初始化虚拟环境,初始化过程中需要填入作者、项目等信息
pdm init
# 安装emmett
pdm add emmett
复制代码


3、修改启动命令


这里,我们使用pdm script来启动emmett,实际和emmett run develop效果一样。关于pdm的用法可以点击这里


使用pdm初始化成功后,项目中会有pyproject.toml文件,我们在其中配置pdm script就好。


[project]
name = ""
version = ""
description = ""
authors = [
    {name = "phyger", email = "phygerr@gmail.com"},
]
dependencies = [
    "emmett>=2.4.5",
]
requires-python = ">=3.7"
license = {text = "MIT"}
[project.urls]
homepage = ""
[tool]
[tool.pdm]
[tool.pdm.scripts]
dev = "emmett develop --port 7777"       ## 这里就是emmett启动命令的配置
[build-system]
requires = ["pdm-pep517"]
build-backend = "pdm.pep517.api"
复制代码


4、开发Emmett Api


我们在项目根路径创建app.py文件,并向其中写上视图代码。


from emmett import App,url,request
app = App(__name__)
# 渲染字符串
@app.route("/")
async def hello():
    return "Hello world!"
# 请求参数/hi?name=phyger
@app.route("/hi")
async def hi():
    user = request.query_params.name
    return f"hi,{user}!"
# 路径参数
# 模板渲染
#    1.在项目根路径下创建templates文件夹,并创建templates/index.html
#    2.其中函数名index和模板文件index.html名相同才能识别
@app.route('/tm/<str:info>')
async def index(info):
    return dict(msg=info)
复制代码


index.html的内容如下:


<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title>halo</title>
        <link rel="stylesheet" href="https://www.layuicdn.com/layui-v2.6.8/css/layui.css"/>
    </head>
    <body>
        <ul class="layui-nav" lay-filter="">
          <li class="layui-nav-item"><a href="">菜单A</a></li>
          <li class="layui-nav-item layui-this"><a href="">菜单B</a></li>
          <li class="layui-nav-item"><a href="">菜单C</a></li>
          <li class="layui-nav-item">
            <a href="javascript:;">下拉菜单</a>
            <dl class="layui-nav-child"> <!-- 二级菜单 -->
              <dd><a href="">Python</a></dd>
              <dd><a href="">Golang</a></dd>
              <dd><a href="">Java</a></dd>
            </dl>
          </li>
          <li class="layui-nav-item"><a href="">社区</a></li>
        </ul>
        <br>
        <button type="button" class="layui-btn">{{=msg}}</button>
        <script src="https://www.layuicdn.com/layui-v2.6.8/layui.js"></script>
    </body>
</html>
复制代码


我们在index.html中使用了Emmett的模板语法,双大括号的写法。同时我们借助LayUI实现页面美化。


5、启动项目并预览


在完成以上步骤后,我们使用pdm run dev启动Emmett项目。


网络异常,图片无法展示
|


打开localhost:7777/tm/你好啊查看效果。


网络异常,图片无法展示
|


可以看到,页面和数据已近被成功渲染。


进阶-ORM应用


在Emmett的进阶中,我们对其ORM功能进行简单介绍。

假设我们想要通过Emmett接口实现对数据表的查询。


1、定义Model


我们在项目根目录创建orm文件夹,并在orm下创建user.py文件,在其中定义model。


from emmett.orm import Model, Field
# 这是一个简单到的博客Model
class Post(Model):
    author = Field()
    title = Field()
    body = Field.text()
复制代码


2、设计Api


注意:我们不需要自己创建数据库文件和表结构,这些操作Emmett都会帮我们完成。


from emmett import App,url,request
# 导入user.py中的Post Model类
from orm.user import Post
# 导入Emmett内置的Database类
from emmett.orm import Database
app = App(__name__)
# 配置数据库信息
app.config.db.uri = "sqlite://storage.db"
# 初始化db实例,并且设置数据库自动连接,自动同步表结构
db = Database(app,auto_connect=True,auto_migrate=True)
# 初始化表结构
db.define_models(Post)
# 建立连接
app.pipeline = [db.pipe]
@app.route("/orm/<str:author>")
async def getPost(author):
    # 首次我们可以使用这条代码创建一条数据
    #Post.create(author=author,title='test',body='hahaha')
    # 查询author==author的文章,并且将第一条博客的内容返回
    posts = db(Post.author == author).select()
    return dict(posts=posts[0].body,msg='ok')
复制代码


3、indx.html


...
<button type="button" class="layui-btn">{{=msg}}</button>
<h1>posts:{{ =posts }}</h1>
...
复制代码


4、完整的项目结构


网络异常,图片无法展示
|


5、测试


我们在浏览器打开http://127.0.0.1:7777/orm/phyger看看效果


网络异常,图片无法展示
|


数据库中的数据


网络异常,图片无法展示
|


参考:emmett.sh/docs


更多内容>>>

相关文章
|
2月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
58 4
|
2月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
158 3
|
2月前
|
SQL 安全 PHP
PHP 自发布以来一直在 Web 开发领域占据重要地位,PHP 8 更是带来了属性、刚性类型等新特性。
【10月更文挑战第1天】PHP 自问世以来,凭借其易用性和灵活性,在 Web 开发领域迅速崛起。从简单的网页脚本语言逐步演进为支持面向对象编程的现代语言,尤其自 PHP 5.3 引入命名空间后,代码组织和维护变得更加高效。PHP 7 的性能优化和 PHP 8 的新特性(如属性和刚性类型)进一步巩固了其地位。框架如 Laravel、Symfony、Yii2 和 CodeIgniter 等简化了开发流程,提高了效率和安全性。
54 2
|
1月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
168 45
|
26天前
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。
|
25天前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
35 2
|
27天前
|
中间件 Go API
Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架
本文概述了Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架。
69 1
|
1月前
|
SQL 安全 PHP
探索PHP的现代演进:从Web开发到框架创新
PHP是一种流行的服务器端脚本语言,自诞生以来在Web开发领域占据重要地位。从简单的网页脚本到支持面向对象编程的现代语言,PHP经历了多次重大更新。本文探讨PHP的现代演进历程,重点介绍其在Web开发中的应用及框架创新,如Laravel、Symfony等。这些框架不仅简化了开发流程,还提高了开发效率和安全性。
30 3
|
1月前
|
前端开发 JavaScript 开发工具
从框架到现代Web开发实践
从框架到现代Web开发实践
44 1
|
1月前
|
SQL 安全 PHP
探索PHP的现代演进:从Web开发到框架创新
PHP 自发布以来一直在 Web 开发领域占据重要地位,历经多次重大更新,从简单的脚本语言进化为支持面向对象编程的现代语言。本文探讨 PHP 的演进历程,重点介绍其在 Web 开发中的应用及框架创新。自 PHP 5.3 引入命名空间后,PHP 迈向了面向对象编程时代;PHP 7 通过优化内核大幅提升性能;PHP 8 更是带来了属性、刚性类型等新特性。
30 3