Flask学习之改编成你认识的MVC结构

启动剥离

from app.Kernel import Kernel

### 启动
if __name__ == '__main__':
    Kernel.bootstrap()

启动文件

### 初始化项目
app = Flask(__name__, template_folder=env.TEMPLATE, static_folder=env.STATIC)
app.debug = env.DEBUG


@classmethod
    def bootstrap(cls):
        return cls.app.run( host=env.HOST, port=env.PORT )

数据库剥离

#### 数据库实例化
try:
    Database.init( app )
except Exception as e:
    raise AttributeError( f'数据库链接异常:{e}' )

模型注入

"""
初始化数据库驱动
"""
@classmethod
def init(cls, app ):
    try:
        if 'mysql' == cls.config.default:
            cls.driver = Mysql( cls.config.drivers[cls.config.default] )

    except Exception as e:
        raise Exception( e )

    app.config.from_object( cls.driver )
    Base.inject_app( app )

    return True

模型基类

from flask_sqlalchemy import SQLAlchemy

class Base:
    db = SQLAlchemy()

    def __init__(self):
        pass

    @classmethod
    def inject_app(cls, app):
        cls.db.init_app( app )

        return cls.db

模型改写

#### 引入基类
from Flask.app.Models.Base import Base

###### Base.db.Model Flask模型基类
class Users( Base.db.Model ):
    """
    站点数据表映射
    """
    ### 改写db指向
    db = Base.db
    
    ### 映射表名称
    __tablename__ = 'users'

    id = db.Column(db.Integer, primary_key=True, autoincrement=True )
    created_at = db.Column(db.DateTime, nullable=False )
    updated_at = db.Column(db.DateTime, nullable=False )
    name = db.Column(db.String(32),  index = True, nullable=False )
    email = db.Column(db.String(64), unique=True, index = True, nullable=False )
    password = db.Column(db.String(64), unique=True, index = True, nullable=False )
    email_verified_at = db.Column( db.Time )
    email_verified_at = db.Column(db.String(100))

    # 关联关系
    """
    lazy: 指定sqlalchemy数据库什么时候加载数据
       select: 就是访问到属性的时候,就会全部加载该属性的数据
       joined: 对关联的两个表使用联接
       subquery: 与joined类似,但使用子子查询
       dynamic: 不加载记录,但提供加载记录的查询,也就是生成query对象
    """
    sites = db.relationship( "Sites", backref='user', uselist=True, lazy='dynamic' )

    def __repr__(self):
        return '<Users %s>' % self.name

如上述代码中关联关系设置关键词:  Lazy dynamic

那么这里设置的是动态加载,那么我们获取到数据之后管理查询时就需要重新去查询。

#关联取数据
user = Users.query.get(1)

sites = user.sites.all()
for item in sites :
    print( f"站点编号:{item.id}, 站点名称:{item.name}, 创建人:{item.user.name}, 站点邮件:{item.email}, 站点电话:{item.phone}, 创建时间:{item.created_at}")

模型操作

查找
### 查找
#### get 主键查找
site = Sites.query.get(1)
print( f"站点编号:{site.id}, 站点名称:{site.name}, 创建人:{site.user.name}, 站点邮件:{site.email}, 站点电话:{site.phone}, 创建时间:{site.created_at}" )

#### filter_by
sites = Sites.query.filter_by( name='www.google.com' )
print(f"站点编号:{site.id}, 站点名称:{site.name}, 站点邮件:{site.email}, 站点电话:{site.phone}, 创建时间:{site.created_at}")

for item in sites:
    print(f"站点编号:{item.id}, 站点名称:{item.name}, 站点邮件:{item.email}, 站点电话:{item.phone}, 创建时间:{item.created_at}")
修改
### 修改
site.email='email@google.com'
db.session.commit()
删除
# ### 删除
site = Sites.query.get(7)
db.session.delete( site )
db.session.commit()

路由剥离

from flask import Blueprint

### 初始化 Blueprint
bp = Blueprint( 'dashbord', __name__, url_prefix='/' )


"""
System Index
后端数据传递 - 多参数传递视图 , 分割
"""
@bp.route( '/index', methods=['GET'] )
@bp.route( '/', methods=['GET'] )
def dashbord():
    data = {
        'uid': 1,
        'uname': "Carey"
    }

    return render_template( 'index.html', user = data )
### 引入路由模块
from Flask.app.Controller.dashbord import bp


#### 模块注入
app.register_blueprint(bp)

 

Gitee链接地址 : Flask 更改为MVC: Python Flask框架改为MVC

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt中的MVC(Model-View-Controller)模式是一种常用的软件架构模式,用于将应用程序的数据、用户界面和业务逻辑分离开来,以实现更好的代码组织和可维护性。 在Qt中,MVC模式可以通过自定义的控制器来实现。具体来说,Qt的MVC架构可以描述为Model/View,并通过自定义的控制器来实现Model/View/Controller的设计模式。 在这种架构中,Model负责管理应用程序的数据,View负责显示数据和与用户交互,而Controller负责处理用户输入并更新Model和View之间的关系。 通过使用MVC模式,可以实现以下优点: 1. 分离关注点:MVC模式将数据、用户界面和业务逻辑分离开来,使得代码更易于理解和维护。 2. 可扩展性:由于模块之间的松耦合性,可以更容易地添加新的功能或修改现有功能。 3. 可重用性:通过将数据和界面分离,可以更容易地重用模型和视图组件。 4. 可测试性:由于模块之间的明确分离,可以更容易地对模型、视图和控制器进行单元测试。 以下是一个简单的示例代码,演示了如何在Qt中实现MVC架构: ```cpp // Model class DataModel : public QObject { Q_OBJECT public: // 数据相关的方法和属性 }; // View class DataView : public QWidget { Q_OBJECT public: // 显示数据和处理用户交互的方法和属性 }; // Controller class DataController : public QObject { Q_OBJECT public: DataController(DataModel* model, DataView* view) : m_model(model), m_view(view) { // 处理用户输入并更新模型和视图之间的关系 } private: DataModel* m_model; DataView* m_view; }; int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建模型、视图和控制器 DataModel model; DataView view; DataController controller(&model, &view); // 显示视图 view.show(); return app.exec(); } ``` 这个示例代码展示了一个简单的MVC架构,其中Model负责管理数据,View负责显示数据和与用户交互,Controller负责处理用户输入并更新Model和View之间的关系。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值