会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132463个问题
Python 全系列/第二阶段:Python 深入与提高/异常机制 5958楼
Python 全系列/第一阶段:Python入门/Python入门(动画版) 5960楼
Python 全系列/第五阶段:数据库编程/mysql的使用 5962楼
JAVA 全系列/第一阶段:JAVA 快速入门/控制语句、方法、递归算法 5963楼

from tkinter import *
from tkinter.filedialog import *
from tkinter.colorchooser import *
from tkinter.filedialog import *

class Application(Frame):

    def __init__(self,master=None):
        super().__init__(master)
        self.master = master
        self.textpad = None     # textpad表示Text文本框对象
        self.pack()
        self.createWidget()

    def createWidget(self):
        # 创建主菜单栏
        menubar = Menu(root)
        # 创建子菜单
        menuFile = Menu(menubar)
        menuEdit = Menu(menubar)
        menuHelp = Menu(menubar)

        # 将子菜单加入到主菜单栏
        menubar.add_cascade(label='文件(F)',menu=menuFile)
        menubar.add_cascade(label='编辑(E)', menu=menuEdit)
        menubar.add_cascade(label='帮助(H)', menu=menuHelp)

        # 添加菜单项
        menuFile.add_command(label='新建',accelerator='ctrl+n',command=self.test)
        menuFile.add_command(label='打开',accelerator='ctrl+o',command=self.openfile)
        menuFile.add_command(label='保存',accelerator='ctrl+s',command=self.savefile)
        menuFile.add_separator()    # 添加分割线
        menuFile.add_command(label='退出',accelerator='ctrl+q',command=self.test)

        # 将主菜单栏加到根窗口
        root['menu'] = menubar

        # 文本编辑区
        self.textpad = Text(root, width=50, height=30)
        self.textpad.pack()

        # 创建上下菜单
        self.contextMenu = Menu(root)
        self.contextMenu.add_command(label='背景颜色',command=self.test)

        #为右键绑定事件
        root.bind('<Button-3>',self.createContextMenu)

    def openfile(self):
        with askopenfile(title='打开文本文件') as f:
            self.textpad.insert(INSERT,f.read())
            self.filename = f.name

    def savefile(self):
        with open(self.filename,'w') as f:
            c = self.textpad.get(1,0,END)
            f.write(c)

    def test(self):
        pass

    def createContextMenu(self,event):
        # 菜单在鼠标右键单击的坐标处显示
        self.contextMenu.post(event.x_root,event.y_root)


if __name__ == '__main__':
    root = Tk()
    root.geometry('400x400')
    root.title('百战程序员的简易记事本')
    app = Application(master=root)
    root.mainloop()

1630227021(1).png

老师,这是出现了什么问题

Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 5964楼
Python 全系列/第十阶段:Flask百战电商后台项目/Flask百战电商后台项目 5965楼
JAVA 全系列/第一阶段:JAVA 快速入门/JAVA入门和背景知识 5966楼

捕获.PNG

新建项目时,项目目录缺少,并且pom.xml文件第一行报错,怎么解决

JAVA 全系列/(旧的隐藏)第七阶段:JAVA 高级技术/Maven 5967楼
Python 全系列/第一阶段:Python入门/控制语句 5968楼
Python 全系列/第十五阶段:Python 爬虫开发/爬虫基础 5969楼

代码:

<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百战电商后台项目 5970楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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