微信小程序入门

微信小程序入门 微信小程序介绍 微信小程序介绍 ​ 微信小程序,简称小程序,是一种不需要下载安装即可使用的应用,它实现了应用”触手可及”的梦想,用户扫一扫或搜一下即可打开应用。 ​ 说明: 小程序是需要下载的,小程序的占用大小很小,感觉不到下载 目前大小限制2M (最终开发的小程序打包压缩后的大小),如果超过2M,就得做分包上传.之后再合并 进入小程序后继续网络请求数据 小程序特点 微信小程序的特点: ...

2023-03-02 · 30 min · 14652 words · Waite Wang

系统学习 Vue -- 2-深入组件

认识组件化开发 认识组件化开发 人面对复杂问题的处理方式: 任何一个人处理信息的逻辑能力都是有限的 所以,当面对一个非常复杂的问题时,我们不太可能一次性搞定一大堆的内容。 但是,我们人有一种天生的能力,就是将问题进行拆解。 如果将一个复杂的问题,拆分成很多个可以处理的小问题,再将其放在整体当中,你会发现大的问题也会迎刃而解。 组件化也是类似的思想: 如果我们将一个页面中所有的处理逻辑 全部放在一起,处理起来就会变得非常复杂,而且不利于后续的管理以及扩展; 但如果,我们讲一个页面拆分成一个个 小的功能块,每个功能块完成属于自己 这部分独立的功能,那么之后整个页面 的管理和维护就变得非常容易了; 如果我们将一个个功能块拆分后,就可 以像搭建积木一下来搭建我们的项目; 现在可以说整个的大前端开发都是组件化的天下,无论从三大框架(Vue、React、Angular),还是跨平台方案 的Flutter,甚至是移动端都在转向组件化开发,包括小程序的开发也是采用组件化开发的思想 所以,学习组件化最重要的是它的思想,每个框架或者平台可能实现方法不同,但是思想都是一样的。 我们需要通过组件化的思想来思考整个应用程序: 我们将一个完整的页面分成很多个组件; 每个组件都用于实现页面的一个功能块; 而每一个组件又可以进行细分; 而组件本身又可以在多个地方进行复用; Vue的组件化 vue 项目起始文件 createApp 函数传入了一个对象App,这个对象其实本质上就是一个组件,也是我们应用程序的根 组件; 组件化提供了一种抽象,让我们可以开发出一个个独立可复用的小组件来构造我们的应用; 任何的应用都会被抽象成一颗组件树; ...

2023-02-07 · 41 min · 20536 words · Waite Wang

系统学习 Vue 1

邂逅 Vue 认识 Vue 什么是 Vue Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。 全程是Vue.js或者Vuejs; 什么是渐进式框架呢?表示我们可以在项目中一点点来引入和使用Vue,而不一定需要全部使用Vue来开发整个 项目; Vue3带来的变化 源码通过monorepo的形式来管理源代码: Mono:单个 Repo:repository仓库 主要是将许多项目的代码存储在同一个 repository 中; 这样做的目的是多个包本身相互独立,可以有自己的功能逻辑、单元测试等,同时又在同一个仓库下方便管理; 而且模块划分的更加清晰,可维护性、可扩展性更强; 源码使用TypeScript来进行重写: 在Vue2.x的时候,Vue使用 Flow 来进行类型检测; 在Vue3.x的时候,Vue的源码全部使用 TypeScript 来进行重构,并且 Vue 本身对 TypeScript 支持也更好了; 性能方面 使用Proxy进行数据劫持 在 Vue2.x 的时候,Vue2 是使用 Object.defineProperty 来劫持数据的 getter 和 setter 方法的; 这种方式一致存在一个缺陷就是当给对象添加或者删除属性时,是无法劫持和监听的; 所以在 Vue2.x 的时候,不得不提供一些特殊的API,比如 $set 或 $delete ,事实上都是一些 hack 方法,也增加了 开发者学习新的API的成本; 而在 Vue3.x 开始,Vue 使用 Proxy 来实现数据的劫持 删除了一些不必要的API: 移除了实例上的 $on , $off 和 $once; 移除了一些特性:如filter、内联模板等; 包括编译方面的优化: 生成Block Tree、Slot编译优化、diff算法优化; 新的API 由Options API 到 Composition API: 在 Vue2.x 的时候,我们会通过 Options API 来描述组件对象; Options API 包括data、props、methods、computed、生命周期等等这些选项; 存在比较大的问题是多个逻辑可能是在不同的地方: 比如created中会使用某一个method来修改data的数据,代码的内聚性非常差; Composition API可以将 相关联的代码 放到同一处 进行处理,而不需要在多个Options之间寻找; Hooks函数增加代码的复用性: 在Vue2.x的时候,我们通常通过mixins在多个组件之间共享逻辑;但是有一个很大的缺陷就是 mixins也是由一大堆的Options组成的,并且多个mixins会存在命名冲突的问题; 在Vue3.x中,我们可以通过Hook函数,来将一部分独立的逻辑抽取出去,并且它们还可以做到是响应式的; 如何使用 Vue 方式一:在页面中通过CDN的方式来引入; 方式二:下载Vue的JavaScript文件,并且自己手动引入; 方式三:通过npm包管理工具安装使用它; 方式四:直接通过Vue CLI创建项目,并且使用它; CDN 引入 <script src="https://unpkg.com/vue@next"></script> 下载和引入 下载Vue的源码,可以直接打开CDN的链接: 打开链接,复制其中所有的代码; 创建一个新的文件,比如vue.js,将代码复制到其中; <script src="../js/vue.js"></script> 声明式编程和命令式编程 原生开发和Vue开发的模式和特点,我们会发现是完全不同的,这里其实涉及到两种不同的编程范式命令式编程和声明式编程 命令式编程关注的是“ how to do”,声明式编程关注的是" what to do",由框架(机器)完成"how"的过程 MVVM模型 MVC和MVVM都是一种软件的体系结构 MVC是 Model-View-Controller的简称,是在前期被使用非常框架的架构模式,比如iS、前端 MVVM是 Model-View- ViewMode的简称,是目前非常流行的架构模式 通常情况下,我们也经常称vue是一个MVVM的框架 vue官方其实有说明,vue虽然并没有完全遵守MVVM的模型,但是整个设计是受到它的启发的 ...

2023-01-02 · 82 min · 40770 words · Waite Wang

Idea2023.2 创建 Servlet 项目

Idea2023.2 创建 Servlet 项目 前期准备 正常创建 Java 项目, 添加框架支持 Web 模块 2023.2 之后 Idea 新 UI 把添加框架支持移到了 Ctrl + Alt + Shift + S(项目结构) -> 模块 -> + 如果想要之前一样右键添加框架支持, 可以设置 -> 添加按键映射 -> 添加快捷键 -> 之后用快捷键使用即可 ...

2022-10-23 · 1 min · 454 words

JSP 访问数据库

JSP 访问数据库 mysql-connector-java的jar包下载 官方下载地址 https://dev.mysql.com/downloads/connector/j/ 解压, 把JDBC驱动放在lib文件夹下(直接复制过来就可以了) 记得导入, 不然会报错 <%@ page import="java.sql.*" %> 基本用法 连接MySQL数据库 在JSP中连接MySQL数据库的步骤如下: ...

2022-10-23 · 5 min · 2168 words

nvm 的使用

nvm 的使用 nvm 可以快速的切换 nodejs 的版本 nvm 是什么? nvm 是一个 node 的版本管理工具,可以简单操作 node 版本的切换、安装、查看。。。等等,与 npm 不同的是,npm 是依赖包的管理工具。 ...

2022-10-22 · 1 min · 315 words

Tomcat + Idea 配置及使用

Jdk 安装 Tomcat 注意 Tomcat 版本与 Jdk 匹配 官网地址:https://tomcat.apache.org/ 我这里选择的是Tomcat9.0版本,大家可以选择自己需要的版本 ...

2022-10-22 · 3 min · 1295 words

hadoop的安装与配置

安装JDK 1.创建工作路径 mkdir /usr/cx 2.解压安装包 tar -zxvf 安装包位置 -C /usr/cx 3.配置环境变量 vi ~/.bashrc 在打开的~/.bashrc文件中写入一下内容 # .bashrc # User specific aliases and functions alias rm='rm -i' alias cp='cp -i' alias mv='mv -i' # Source global definitions if [ -f /etc/bashrc ]; then . /etc/bashrc fi (----------------注:需要在此处增加内容-------------------) --在这添加-- export JAVA_HOME=/usr/cx/jdk名字版本 export PATH=$JAVA_HOME/bin:$PATH export CLASSPATH=:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/jre/lib/tools.jar 4.更新环境变量 ...

2022-10-10 · 40 min · 19581 words