会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 128778个问题
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 46楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 49楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 50楼

老师这节课的代码原封不动的照抄下来了,
虽然实现了一模一样的功能,但是具体的逻辑没理解 真没听懂

又不想傻傻的不动脑筋 老师敲一行就跟一行 ,这样项目经验基本为0 
 
 所以换了一个方法 用之前课堂老师再flask第106节课讲的知识点
 关于SQLAlchemy数据分页的 讲解
 
   # #换一个之前falsk课学过能理解的方法 来
        username=request.args.get('username')
        pagenum=request.args.get('pagenum','1')       # 当数据没有传递的时候 默认值是1   页码
        pagesize=request.args.get('pagesize','2')     #当这个参数没有传递的时候 默认值是2 对应的每页显示的数据
        if not pagenum.isdigit():  #当用户传递参数 传入的不是数字 是乱七八糟的字符的时候 直接给干掉!
            return {"status":400,"msg":"页码必须是数字!",}
        if not pagesize.isdigit():
            return {"status":400,"msg":"每页显示的数量必须是数字!",}
        pagestart=int(pagesize)*(int(pagenum)-1)         #切片起始点  对应的是课堂老师当初分析数据分页的逻辑
        page_end=int(pagesize)*int(pagenum)              #切片终点
        '''页码是1 分页显示的数据量是2   就是0到1两条数据 。 页码是2 分页显示的数据量是2 就是显示 2和3这2条数据  往后类推'''
        #查询数据 
        user_list=User.query.filter(User.username.like(f'%{username}%')).slice(pagestart,page_end).all()
        data={
            "total":int(pagenum), #发给前端还是数字吧   免得到时候再vue里面用的时候或许还要转换一下
            "page_num":int(pagesize),  
            "data":[]
        }
        for i in user_list:
            data['data'].append(i.to_dict())
        return {"status":200,"msg":"数据查询成功","data":data}


Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 51楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 54楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 56楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 57楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 58楼

代码:

<template>
    <editor v-model="textContent" :init="init"></editor>
</template>

<script setup>
import tinymce from 'tinymce/tinymce'
//tinymce默认hidden,不引入不显示
import Editor from '@tinymce/tinymce-vue'
import 'tinymce/themes/silver/theme' // 主题件
import 'tinymce/icons/default'
import 'tinymce/models/dom' // Bug修复
// tinymce插件可按自己的需要进行导入
// 更多插件参考:https://www.tiny.cloud/docs/plugins/
import 'tinymce/plugins/image' // 插入上传图片插件
import "tinymce/plugins/importcss"; //图片工具
import 'tinymce/plugins/media' // 插入视频插件
import 'tinymce/plugins/table' // 插入表格插件
import 'tinymce/plugins/lists' // 列表插件
import "tinymce/plugins/charmap"; // 特殊字符
import 'tinymce/plugins/wordcount' // 字数统计插件
import "tinymce/plugins/codesample"; // 插入代码
import "tinymce/plugins/code"; // 查看源码
import "tinymce/plugins/fullscreen"; //全屏
import 'tinymce/plugins/link' //
import 'tinymce/plugins/preview' // 预览
import "tinymce/plugins/template"; //插入模板
import 'tinymce/plugins/save' // 保存
import "tinymce/plugins/searchreplace"; //查询替换
import "tinymce/plugins/pagebreak"; //分页
import "tinymce/plugins/insertdatetime"; //时间插入

import { reactive, ref, watch, onMounted }
    from "vue"

const emit = defineEmits(["onDataEvent"])

const props = defineProps({
    value: {
        type: String,
        default: ''
    },
    plugins: {
        type: [String, Array],
        default: 'lists image media tablewordcount save preview'
    },
    toolbar: {
        type: [String, Array],
        default: 'undo redo | formatselect | bold italic underline strikethrough forecolor backcolor | alignleft' +
            'aligncenter alignright alignjustify | bullist numlist outdent indent blockquote | lists image' +
            'media table | codesample code removeformat save preview'
        // default: 'formats undo redo paste
        // print fontsizeselect fontselect template
        // fullpage | wordcount ltr rtl visualchars
        // visualblocks toc spellchecker
        // searchreplace | save preview pagebreak
        // nonbreaking | media image | outdent indent
        // aligncenter alignleft alignright
        // alignjustify lineheight underline quicklink
        // h2 h3 blockquote numlist bullist table
        // removeformat forecolor backcolor bold italic
        // strikethrough hr charmap link
        // insertdatetime | subscript superscript cut
        // codesample code | anchor preview
        // fullscreen | help'
    }
})

const init = reactive({
    width: 720,
    height: 300,
    language_url: '/tinymce/langs/zh-Hans.js',
    language: 'zh-Hans',
    // 皮肤:这里引入的是public下的资源文件
    skin_url: '/tinymce/skins/ui/oxide',
    // skin_url:'tinymce/skins/ui/oxide dark',//黑色系
    plugins: props.plugins,
    toolbar: props.toolbar,
    content_css:
    '/tinymce/skins/content/default/content.css', branding: false,
    // 隐藏菜单栏
    menubar: false,
    // 是否显示底部状态栏
    statusbar: true,
    // convert_urls: false,
    // 初始化完成
    init_instance_callback: (editor) => {
    console.log("初始化完成:", editor)
},
    // 此处为图片上传处理函数,这个直接用了base64的图片形式上传图片,
// 如需ajax上传可参考 https://www.tiny.cloud/docs/configure/file-image-upload/#images_upload_handler
    images_upload_handler: (blobInfo,success, failure) => {
        const img =
        'data:image/jpeg;base64,' +
        blobInfo.base64()
    console.log("图片上传处理:", img)
    success(img)
}
})
    const textContent = ref("")

    watch(props.value, (newValue, oldValue) => {
        textContent.value = newValue
})
    watch(textContent, (newValue, oldValue) => {
    emit("onDataEvent", newValue)
})
onMounted(() => {
    // 初始化 tinymce
    tinymce.init({})
})
</script>


Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 59楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 60楼

百战程序员微信公众号

百战程序员微信小程序

©2014-2024 百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637