自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(51)
  • 资源 (3)
  • 收藏
  • 关注

原创 Vue应用多语言支持工程化最佳实践

VoerkaI18n一款非常优开源多语言解决方案,本节主要介绍如何在Vue 3应用中使用VoerkaI18n

2024-01-09 20:01:37 1216

原创 编写Markdown时如何爽爽地渲染树?

在使用等静态网站生成时,一般均支持直接在Markdown中渲染显示Vue/React组件,这给个网站非常丰富极致的表现力,我们在创建静态网站时开心的使用各种Vue/ReactJSON因此,隆重推荐LiteTree这个适用于React/Vue的树组件,专用MarkDownLiteYAML。

2024-04-09 11:33:29 787

原创 一个解析非标JSON数据的思路 - [Flex-Tools]

中也可能会使用一些第三方的库。内部可能包含一系列的符号或转义符等不利于进行后续的正则匹配。使用以下正则表达式匹配行未添加正则表达式。将一些全角字符转换为半角字符,同时使用。解析上述字符串,则会出错。如果追求解析性能,在。包裹字符串,然后使用。

2024-03-29 14:30:13 509

原创 这个Vue树组件非常适合在vitepress中使用

一款非常适合在vitepress中使用的树组件,具有简单小巧,容错性高等特点

2024-03-19 14:46:31 970

原创 自动捆绑Vue组件CSS样式-CSS-IN-JS

`vite-plugin-vue-style-bundler`可以实现, 自动提取`Vue`组件中的`css`样式一起打包到`js`源代码中,然后在运行时将`style`自动插入到`head`的`vite`插件。

2024-03-18 20:45:40 479

原创 基于有限状态机开发健壮的Nodejs/TCP客户端

`FlexState`是一款简单易用的有限状态机,本文介绍如何基于有限状态机来开发一款键壮的TCP客户端

2024-03-14 15:25:08 908

原创 轻松玩转Vite/Rollup/webpack/esbuild/Rspack/babel插件开发(二)

介绍如何使用unplugin开发一个简单的define插件

2024-03-11 17:26:10 357

原创 轻松玩转Vite/Rollup/webpack/esbuild/Rspack/babel插件开发(一)

`Unplugin`提供了一个非常简单的API,适配`Vite/Rollup/webpack/esbuild/Rspack/`,只需要开发一个`unplugin`就可以输出`Vite/Rollup/webpack/esbuild/Rspack/`插件。

2024-03-11 10:55:05 793

原创 Vue2/3如何强制重新渲染整个页面

VoerkaI18n是一个非常优秀的前端多语言解决方案库,提供初始化、提取文本、自动翻译、编译、自动补丁等工具链支持。本文介绍了在开发@voerkai18n/vue时如何制刷新页面的经验和技巧

2024-03-05 10:32:32 1750

原创 前端link调试神器:从yalc到yald

`yalc`是前端link调试的好工具,但好久没更新了,不支持publishConfig,所以就fork了yald,支持publishConfig

2024-03-02 16:55:13 365

原创 我的一大波开源项目推荐

我的一大波开源项目推荐:

2024-03-02 15:14:44 310

原创 新鲜出炉:小巧优雅的 css-in-js库StyledFc

一个非常小巧优雅的css-in-js库,用于创建React组件

2024-02-20 15:42:49 985

原创 monorepo工程开发交互nodejs命令行程序

为monorepo应用开发命令行程序提供了一套解决方案,提供了更加友好的命令行开发体验。

2024-01-10 21:40:02 479

原创 开发超爽的nodejs命令行程序

开发nodejs命令行程序以一般会到什么库?commander有了以下三板斧,基本上就可以写出一个很好命令行程序了吗?如果想要更爽些,则推荐使用MixedCli。是一个命令行应用开发框架,其主要是对commander/prompts/logsets的封装,提供了更加友好的命令行开发体验。

2024-01-10 21:37:53 811

原创 开发React应用的多语言支持最佳实践

[VoerkaI18n](https://zhangfisher.github.io/voerka-i18n/#/)是一款非常优秀的**全新的开源国际化多语言解决方案,本文介绍如何在React使用多语言

2024-01-09 19:58:26 1286

原创 前端国际化之痛点(三):上线后修改翻译内容

VoerkaI18n是一款非常优秀的前端国际化解决方案,其开发的出发点是为了解决现存多语言的一些痛点,接下来几篇文章将分别进行分析。

2024-01-09 18:03:24 1021

原创 前端国际化之痛点(二):多包多库场景下联动多语言

介绍前端国际化方案

2024-01-09 18:02:04 552

原创 前端国际化之痛点(一):让人头疼的词条Key

介绍前端国际化方案以及痛点

2024-01-09 18:00:56 927

原创 推荐VSCODE插件:为`package.json`添加注释信息

介绍如何为`package.json`添加注释

2024-01-09 17:59:27 598

原创 FreeSwitch源码编译安装方法

准备工作操作系统:debian 8.9 首先更新一个apt-get并安装curlapt-get update && apt-get install curl下载最新的源码按官方推荐的命令,在本机下载最稳定版本的源码。FSfile=$(curl -s https://files.freeswitch.org/releases/freeswitch/ | sed -n

2018-01-24 09:52:02 7254 1

原创 创建python单例实例的装饰器

环境:python 3.5单例模式网上有很多种方法,多少有一些问题,以下是我推荐的两种方法。方法一:使用metaclassclass Singleton(type): def __init__(self, *args, **kwargs): self.__instance = None super().__init__(*args, **kwargs)

2017-06-12 20:57:55 1831

原创 理解Twisted的Deferred机制(二)使用inlineCallbacks实现类同步语法

上文提到使用deferred对象很容易陷入回调地狱中,好在python提供yield生成器语法,可以很容易就包装一套更加友好的异步编程API。就如同ES6提供的Promise等。目前在Twisted中提供了一个inlineCallbacks装饰器。能简化多Deferred操作,先上代码:from twisted.internet.defer import inlineCal

2016-06-20 09:27:27 9053 5

原创 理解Twisted的Deferred机制(一)

Twisted作为Python下的异步网络框架,在异步机制上与Nodejs很相像,但Twisted已经发展了十多年了。为了简化异步编程,Twisted引入了Deferred延迟对象的概念。Deferred是Twisted异步框架内部实现的一套callback调用的机制,或者可以说是一种设计模式。我们都知道jQuery也有一套Deferred机制,用来简化异步编程。Twisted

2016-06-20 09:15:13 5424 1

原创 开发Vue树形组件

使用SemanticUI和vue做一个menubar组件,实现方法大概是这样的: {{item.text}} {{item.label}} //如果有有children则说明是下拉菜单项,然后递归调用自身 0">

2016-04-27 09:15:41 23597 1

转载 理解SQLAlchemy的表继承关系(4)--高级应用

我们创建ORM的基类的目的除了提供公共字段和属性外,还可以实现更高级的功能。在stackoverflow上发现一个应用案例,在此转载一下。class Entry(AbstractConcreteBase, db.Model): """Base Class of Entry.""" id = db.Column(db.Integer, primary_key

2015-12-09 23:04:37 6669

原创 创建SQLAlchemy的ORM类的基类(二)

要为SQLAlchemy的ORM类的基类还有一种方法,就是利用继承的方法来配置。rom sqlalchemy.ext.declarative import declared_attrfrom sqlalchemy.ext.declarative import AbstractConcreteBaseengine = create_engine(...)Base = declarat

2015-12-09 22:51:19 5939

原创 理解SQLAlchemy的表继承关系(3)-Concrete Table Inheritance

Concrete Table Inheritance译成混合继承?这种继承方式会创建一个ORM基类,然后在所有继承表中会创建包含ORM基类定义的字段的独立的表。继承表与ORM基类的关系在数据库层面上没有外健关系,只是在语言层会有继承关系。class Employee(AbstractConcreteBase, Base): id =Column(Integer, pri

2015-12-09 11:45:43 4462

原创 理解SQLAlchemy的表继承关系(2)-Single Table Inheritance

Single Table Inheritance即单表继承,顾名思义,所有继承表的数据均保存在一个表。该种继承比较容易理解。class Employee(Base): __tablename__ = 'employee' id = Column(Integer, primary_key=True name = Column(String(50)) manager_d

2015-12-09 11:36:13 4733

原创 理解SQLAlchemy的表继承关系(1)--Joined Table Inheritance

Joined Table Inheritance指通过外健方式进行链接实现的继承方式。举个例子理解,共三个ORM类: Employee:员工,基类,具有id,name两个共有字段Manager:经理,继承Employee Engineer:工程师,继承Employee,在本例中,SQLAlchemy将会创建三个表,Employee,Manager,Engineerclass

2015-12-09 11:27:12 6131

原创 开源一个基于SQLAlchemy左右值存储的树组件

TreeModel for SQLAlchemy基于SQLAlcemy ORM库,利用左右值原理来实现树状存储的库。什么是左右值树存储原理可以问度娘。SATree可以在一张数据库表中存储多棵树,并可以方便地进行树的增加、删除、移动、输出等。树的一个节点在存储为一条记录,表现为SQLALchemy一个混合了TreeMixin的Model实例。项目地址:

2015-11-05 11:30:21 3585

原创 海尔T520智能扫地机器人使用评测

上个月入手了一台海尔T520智能扫地机器人,被广告忽悠得信心满满。实际使用如何感觉并没有想象中的智能,毛病超多:1、机器人身高限制,在一些沙发、桌子、茶几等底下,如果其高度与机器人身高相当,就比较悲催了,一准卡死。2、在U型的小空间中,机器人一进去就出不来,或者必须要很久才可以出来。3、地面如果有一些像拖鞋什么的小物件,爬上去下不来的几率也超高。4、在房间内的活动基本上

2015-10-29 11:40:54 8645 1

原创 SQLAlchemy中设置Column的默认值

在使用SQLAlchemy时,如果主健使用uuid时import uuidid = db.Column(db.String(32), default=uuid.uuid4().hex, primary_key=True)上述写法,如果在进行批量增加时,会出现“主关健字重复”的错误正确的做法应该是def gen_id():   return uuid.

2015-09-12 23:44:17 10266

原创 python下取得父文件夹绝对路径的方法

我们知道在python下可以用以下代码:import oscurrent_path=os.path.dirname(__file__)取得父文件夹绝对路径的方法如下:os.path.abspath(os.path.dirname(__file__)+os.path.sep+"..")记录一下!

2015-09-09 17:04:55 8710

原创 存在超自然力量吗?

熵用来描述自然无序状态的指标,现代科学指出,在没有外力作用下自然界的熵总是趋向增加的。也就是说,任何物体在没有外力作用下时,物体会变得无序。因此,房屋道路必须经常打扫,汽车要保养等等。假如这种说明是科学的,那么问题来了,原始地球是如何产生现如今如此丰富多彩、如此复杂奇妙、如此具有复杂形态的生命形态呢?如果没有外力作用,如何有序的生命形态是如何产生并进化的呢?难道仅仅

2015-08-11 09:32:31 2722

原创 理解Flux机制和应用

ReactJS是fackbook推出的UI组件框架,最主要特点就是引入了虚拟DOM的机制,并且提供一个非常优秀的UI组件框架,实现可复用的Web前端组件成为可能。但是ReactJS基本上就是帮助你来开发一个可复用的Web组件的框架,缺少数据双向绑定,依赖注入、绑定等一大堆特性。而在前端开发时,往往需要提供一个完整的机制来进行DOM、数据的管理,由此,各类前端MVVM框架大为流行,像Angu

2015-06-25 20:59:48 9582

原创 创建SQLAlchemy的ORM类的基类(一)

SQLAlchemy功能非常强大,一般来说我们可以采用下面方法建立一个ORM类.from sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy.orm import sessionmakerengine = create_engine('

2015-06-19 16:09:55 7612

原创 比较现实可靠的python模块的安装部署方法

每一个pythoner都知识pip install,安装python模块实现是方便。当一个应用扩展十几二十个python模块时,网上最流行的方法是这样的:1、pip freeze > requirements.txt将包依赖信息保存在requirements.txt文件中。requirements.txt文件的内容大概是这样的:blinker==1.3Flask==

2015-03-26 23:25:38 6078

原创 chrome不能断点调试的解决方法

chrome的调试功能实在是太强大了,相比之下ie的就是一垃圾。最近在调试时出现一种情况,死活不能设置断点,也不能跟踪调试,这下抓狂了。JS也是非常简单的,也没有压缩。为什么就不能调试呢?网上狂搜也没找到什么原因,经过自己一翻瞎折腾,终于解决问题在调试的左下方有一个{}图标,提示“pretty print”,点击,chrome就会另外打开一个:formatted的文

2015-01-15 17:15:34 37935 12

原创 使用Sublime Text搭建python调试环境

pycharm虽然用着爽,但经常

2014-08-14 16:39:04 124446 3

转载 建立一个更高级别的查询 API:正确使用Django ORM 的方式

摘要在这篇文章里,我将以反模式的角度来直接讨论Django的低级ORM查询方法的使用。作为一种替代方式,我们需要在包含业务逻辑的模型层建立与特定领域相关的查询API,这些在Django中做起来不是非常容易,但通过深入地了解ORM的内容原理,我将告诉你一些简捷的方式来达到这个目的。概览当编写Django应用程序时,我们已经习惯通过添加方法到模型里以此达到封装业务逻辑并隐藏实现

2013-04-16 15:44:07 3599

百度Ueditor for Django

Ueditor HTML编辑器是百度开源的HTML编辑器, 本模块帮助在Django应用中集成百度Ueditor HTML编辑器。 安装包中已经集成Ueditor v1.2.2 使用Django-Ueditor非常简单,方法如下: 1、安装方法 **方法一:下载安装包,在命令行运行: python setup.py install **方法二:使用pip工具在命令行运行(推荐): pip install DjangoUeditor 2、在INSTALL_APPS里面增加DjangoUeditor app,如下: INSTALLED_APPS = ( #........ 'DjangoUeditor', ) 3、在urls.py中增加: url(r'^ueditor/',include('DjangoUeditor.urls' )), 4、在models中这样定义: from DjangoUeditor.models import UEditorField class Blog(models.Model): Name=models.CharField(,max_length=100,blank=True) Content=UEditorField('内容 ',height=100,width=500,default='test',imagePath="uploadimg/",imageManagerPath="imglib",toolbars='mini',options={"elementPathEnabled":True},filePath='upload',blank=True) 说明: UEditorField继承自models.TextField,因此你可以直接将model里面定义的models.TextField直接改成UEditorField即可。 UEditorField提供了额外的参数: toolbars:配置你想显示的工具栏,取值为mini,normal,full,代表小,一般,全部。如果默认的工具栏不符合您的要求,您可以在settings里面配置自己的显示按钮。参见后面介绍。 imagePath:图片上传的路径,如"images/",实现上传到"{{MEDIA_ROOT}}/images"文件夹 filePath:附件上传的路径,如"files/",实现上传到"{{MEDIA_ROOT}}/files"文件夹 imageManagerPath:图片管理器显示的路径,如"imglib/",实现上传到"{{MEDIA_ROOT}}/imglib",如果不指定则默认=imagepath。 options:其他UEditor参数,字典类型。参见Ueditor的文档ueditor_config.js里面的说明。 css:编辑器textarea的CSS样式 width,height:编辑器的宽度和高度,以像素为单位。 5、在表单中使用非常简单,与常规的form字段没什么差别,如下: class TestUeditorModelForm(forms.ModelForm): class Meta: model=Blog *********************************** 如果不是用ModelForm,可以有两种方法使用: 1: 使用forms.UEditorField from DjangoUeditor.forms import UEditorField class TestUEditorForm(forms.Form): Description=UEditorField("描述",initial="abc",width=600,height=800) 2: widgets.UEditorWidget from DjangoUeditor.widgets import UEditorWidget class TestUEditorForm(forms.Form): Content=forms.CharField(label="内容",widget=UEditorWidget(width=800,height=500, imagePath='aa', filePath='bb',toolbars={})) widgets.UEditorWidget和forms.UEditorField的输入参数与上述models.UEditorField一样。 6、Settings配置 在Django的Settings可以配置以下参数: UEDITOR_SETTINGS={ "toolbars":{ #定义多个工具栏显示的按钮,允行定义多个 "name1":[[ 'source', '|','bold', 'italic', 'underline']], "name2",[] }, "images_upload":{ "allow_type":"jpg,png", #定义允许的上传的图片类型 "max_size":"2222kb" #定义允许上传的图片大小,0代表不限制 }, "files_upload":{ "allow_type":"zip,rar", #定义允许的上传的文件类型 "max_size":"2222kb" #定义允许上传的文件大小,0代表不限制 },, "image_manager":{ "location":"" #图片管理器的位置,如果没有指定,默认跟图片路径上传一样 }, } 7、其他事项: **本程序基于百度ueditor 1.2.2,安装包里面已经包括了,不需要再额外安装。 **目前暂时不支持ueditor的插件 **Django默认开启了CSRF中间件,因此如果你的表单没有加入{% csrf_token %},那么当您上传文件和图片时会失败

2012-08-28

Django官方文档中文翻译(models部分)

Django官方文档中文翻译(models部分) 非常值得一看,省得去啃原官网的英文了

2012-02-20

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除