KDE踩坑实录 [3月22日更新]

只有写写踩坑文才能维持生活的样子
环境:Fedora 29, KDE 5.55.0

KDE CONNECT找不到设备

原因

没有打开相关端口

解决方法

  • 防火墙是iptables

    1
    2
    sudo iptables -I INPUT -p tcp --dport 1714:1764 -j ACCEPT
    sudo iptables -I INPUT -p udp --dport 1714:1764 -j ACCEPT
  • 防火墙是firewall

    1
    2
    3
    sudo firewall-cmd --zone=public --add-port=1714-1764/tcp --permanent
    sudo firewall-cmd --zone=public --add-port=1714-1764/udp --permanent
    sudo firewall-cmd --reload

material-ui与TS结合的实践

介绍

material-ui

material-ui是一款React下的组件库,它支持绝大部分Material Design所定义的组件。相比其他的React组件库【比如antd,semantic-ui】,它有如下优势:

  • 样式酷炫, 符合年轻人审美
  • 定制化程度强
  • 支持多种CSS写法,如
    1. JSS
    2. Styled-Components
    3. CSS Modules
    4. LESS
    5. SASS/SCSS
  • 完善的Typescript支持

Typescript

Typescript是由微软开发的JavaScript的超集,同时借鉴了Java与C#的优点。相比JavaScript,它的优势在于:

  • 静态类型检查,减少运行时错误
  • 增强IDE的智能提示
  • 强大的社区支持
  • 空安全机制

Umi

umi,中文可发音为乌米,是一个由阿里开源的 react 应用框架。umi 以路由为基础的,支持类 next.js 的约定式路由,以及各种进阶的路由功能,并以此进行功能扩展,比如支持路由级的按需加载。然后配以完善的插件体系,覆盖从源码到构建产物的每个生命周期,支持各种功能扩展和业务需求,目前内外部加起来已有 50+ 的插件。它的主要特性在于:

  • 📦 开箱即用,内置 react、react-router 等
  • 🏈 类 next.js 且功能完备的路由约定,同时支持配置的路由方式
  • 🎉 完善的插件体系,覆盖从源码到构建产物的每个生命周期
  • 🚀 高性能,通过插件支持 PWA、以路由为单元的 code splitting 等
  • 💈 支持静态页面导出,适配各种环境,比如中台业务、无线业务、egg、支付宝钱包、云凤蝶等
  • 🚄 开发启动快,支持一键开启 dllhard-source-webpack-plugin
  • 🐠 一键兼容到 IE9,基于 umi-plugin-polyfills
  • 🍁 完善的 TypeScript 支持,包括 d.ts 定义和 umi test
  • 🌴 与 dva 数据流的深入融合,支持 duck directory、model 的自动加载、code splitting 等等

2018计软院双创大赛,赛后感

从10月初报名,到今天决赛答辩,计软院双创大赛终于落下帷幕。今天终于能闲下心来,谈谈这一路的坎坷。

WSL改造实录

换了新显示器后,原来的arch怎么也识别不出来,很蛋疼,加之之前双系统来回切也有些厌烦了。

最终,想起了被遗弃在角落的WSL。决定加以改造,作为日常使用。

WSL安装过程不再赘述。

pyqt踩坑实录

如何创建一个可编辑的QLabel(双击编辑,回车保存)

  1. 建立一个MyLabel类继承QWidget

  2. 布局中添加两个组件label(继承自QLabel) 和 edit(继承自QLineEdit)

  3. [重要] 设置label显示,edit隐藏

  4. 重写 mouseDoubleClick 方法,使label隐藏,edit显示

  5. 为完成编写操作设置回调(槽函数)。当editingFinished信号发出时触发该槽函数

  6. 坑点:组件创建完需立即加入layout中,否则会炸

  7. Sample

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    class SingleBuddyLabel(QWidget):
    def __init__(self,text):
    super().__init__()
    self.layout = QHBoxLayout(self)
    self.label = QLabel(text)
    self.edit = QLineEdit()
    self.layout.addWidget(self.label)
    self.layout.addWidget(self.edit)

    self.label.show()
    self.edit.hide()
    def save_edit():
    #TODO:
    self.edit.editingFinished.connect(save_edit)

    def mouseDoubleClickEvent(self,event):
    self.label.hide()
    self.edit.show()
    self.edit.setFocus()

ArchLinux安装攻略的补充

闲来无事尝试安装了ArchLinux+WIn10的双系统,踩过不少坑,在官方wiki大神的博客的帮助下,最终完成了安装.成果图如下.效果图

可以看到我又在那篇博客的基础上做了不少微调.故开贴将这些调整之处记录下来,也算是做一个备忘

create-react-app中引入antd和less

create-react-app作为React框架的官方脚手架,以其安装方便,无需配置,开箱即用,而被人所喜爱。但在使用过程中也暴露出不少问题,比如不能按需加载UI框架,以及不支持SASS,LESS等CSS预处理器。下文就将解决这两个问题。

TheHack2018结束啦!

有幸在大佬的PY下进入了这次比赛,比赛的项目我们倾注了不少心血,项目的git仓库(前端部分)会稍后发布,我来大致聊聊比赛的感想

设计模式之策略模式

设计模式第一站

JDK版本:9(Java8的语言特性)

参考书籍:《HEAD FIRST 设计模式》

IDE: IntelliJ IDEA

一键模拟登陆华师大公共数据库!ver2.0

花了我整整一天,终于搞定了,爽到。

花了那么久时间主要原因一个是抓包姿势不对【firefox和chrome的抓包结果不一样让人很绝望啊;一个是工具选择不好【辣鸡jsoup

httpclient还是强啊,自动维持session和cookie的特性着实方便了不少。

目前还有两个待解决的问题,一是验证码要手动输入,二是rsa,pl,ul这几个参数必须首先登陆一次才能拿到(这跟用户名密码绑定的)验证码手动输入的问题不难,图片很好认,用现有的工具很好搞定。第二个就比较困难了,首先我找不到加密脚本的位置orz

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×