Vue+TypeScript 实际开发项目 避坑指南

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue+TypeScript 实际开发项目 避坑指南相关的知识,希望对你有一定的参考价值。

参考技术A Hello :

    最近很多小伙伴们,在赶上用Vue+TypeScript 进行开发 下面由我总结出几点在项目中预到的深坑!仅供参考!!

    本章只提供相似案例!你懂得~~~

科普下 基本语法

<script lang="ts">

import  Component, Vue,Prop  from 'vue-property-decorator';

@Component(

    // 挂载组件

)

export default class AppMain extends Vue 

    @Prop( required: true ) public item!: Route;// 接受 props 对象

    @Prop( default: false ) public isNest!: boolean;// 接受 props 布尔值

    @Prop( default: '' ) public basePath!: string;// 接受 props String

    @Prop( default: [] ) public basePath!: string;// 接受 props Array

    private num:Number = 0; //私有属性

    public//共有属性  initdata()

     

    注:class类定义方法 跟Vue区别 class 直接写方法 不需要加逗号"," 

       Vue 写法

       methods     

             funtion1(),

             function2()

         

      class 写法 

      funtion1()

      function2()



</script>

在函数中 有些变量 或者对象 找不到 this  类型不能赋值 之类的  可以使用 (this as any) 解决

在TS 中 要想使用 windows 此属性 会找不到 可以使用 (windows as any) 解决

在TS 中 要想使用  this.$i18n 此属性 会找不到 可以使用 (this as any).$i18n 解决

 //form表单增加校验 

<script lang="ts">

  import  Component, Vue from 'vue-property-decorator';

  const validate = (rule, value, callback) => 

    if (value.length !== 6) 

      callback(new Error('请输入六个字符'));

     else 

      callback();

    

  ;

   export default class AppMain extends Vue

    demoRules: any = 

      title: [required: true, trigger: 'change', validator:  validate ]

    ;

       
   </script>

最后 有什么 不懂的 参考 

vue-property-decorator

避坑指北CentOS 6源码编译安装Python3.7+

由于某种未知原因,一台老服务器上python3环境不见了,不清楚原安装方法与位置,现重新配置。

cat /etc/issue查看了下发行版信息,是CentOS 6.10。CentOS 6默认安装python版本为2.6,安装python3需要自行下载源码编译。

编译源码

注意

CentOS 6版本yum安装的openssl-devel包版本是1.0.1(使用openssl version查看),目前Python3.7以上使用的openssl版本是1.0.2以上版本,使用默认openssl编译会提示libressl库不兼容此版本的API,需要本机编译openssl库,编译过程会有很多坑。

安装源码依赖软件包

sudo yum install -y zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel expat-devel

这部分依赖软件包有些应该可以不装,可以在编译过程中根据提示错误一个个安装。

注意,由于yum本身就是一个python脚本,在python环境有问题时,这一步安装可能就会有问题,需要先恢复原python2.6的环境。

另外,CentOS 6在2020年11月底官方软件源就停止维护了,如遇到问题,需要更换成阿里云的软件源。

编译openssl 1.0.2

此处没有使用最新版本,酌情选择openssl版本。

下载源码

命令行下载或者浏览器下载,命令行可以使用wget http://www.openssl.org/source/openssl-1.0.2r.tar.gz

编译安装

# 这里没配置prefix,默认安装路径在/usr/local/ssl
./config shared zlib

make

# 表示将标准错误2和标准输出1的缓冲区内容都写入install.log
sudo make install > install.log 2>&1

配置环境

# 养成备份源文件的习惯
sudo mv /usr/bin/openssl /usr/bin/openssl.bak
sudo mv /usr/include/openssl /usr/include/openssl.bak

# 链接新openssl
sudo ln -sf /usr/local/ssl/bin/openssl /usr/bin/openssl
sudo ln -sf /usr/local/ssl/include/openssl /usr/include/openssl

# 将openssl lib路径加入链接路径
echo "export LD_LIBRARY_PATH=/usr/local/ssl/lib:$LD_LIBRARY_PATH" >> ~/.bashrc
source ~/.bashrc

# 查看openssl版本
openssl version

编译python3

下载目标版本源码

去官网https://www.python.org/downloads/,下载完成是一个.tar.gz压缩包,执行解压缩命令:tar zxvf python****.tar.gz

编译安装

进入解压后源码目录,执行如下命令:

# 使用上一步编译的ssl目录
./configure --prefix=/usr/local/python3 --with-openssl=/usr/local/ssl --enable-shared

make

sudo make install

这里--enable-shared记得加上,否则可能会出现找不到so的错误。

由于安装到/usr/local/目录下,所有用户都可以访问,需要su权限安装。

卸载如需要卸载,直接删除/usr/local/python3目录即可。

配置python环境

配置环境变量

不推荐使用此方式,可能会遇到同名可执行程序优先从此目录定位的问题。我在配置过程中就遇到一次。

当前用户的bashrc终端配置文件。如会使用vim,可以使用vim ~/.bashrc直接编辑,也可以使用其他终端工具本地编辑后上传替换。

增加环境变量配置:export PATH="/usr/local/python3/bin":$PATH

编辑完成后使用source ~/.bashrc命令,加载终端配置文件使之生效,这样直接执行python3即可找到该命令了。

更新软连接

/usr/bin/python链接到/usr/local/python3/bin/python3,这样默认使用python3。

sudo mv /usr/bin/python /usr/bin/python.bak

sudo ln -s /usr/local/python3/bin/python3 /usr/bin/python

sudo ln -s /usr/local/python3/bin/python3 /usr/bin/python3

sudo ln -s /usr/local/python3/bin/pip3 /usr/bin/pip

配置动态库

# 将openssl和python3 lib路径加入链接路径。
echo "export LD_LIBRARY_PATH=/usr/local/ssl/lib:/usr/local/python3/lib:$LD_LIBRARY_PATH" >> ~/.bashrc
# 重新加载
source ~/.bashrc

这时配置完,bashrc中应当配置了两条LD_LIBRARY_PATH,export LD_LIBRARY_PATH=/usr/local/ssl/lib:/usr/local/python3/lib:$LD_LIBRARY_PATH

配置yum(可选)

由于CentOS的软件管理工具yum是默认依赖python2的,如果运行出现错误,需要修改yum脚本。

用vim编辑/usr/bin/yum将首行#!/usr/bin/python改为#!/usr/bin/python2.6即可。

其他

如果在python3配置过程中都已经按照说明进行了配置,但是仍有奇怪的问题,可能和python自身的环境变量有关,python2和python3都会使用$PYTHONHOME$PYTHONPATH,可以执行清除命令。

unset $PYTHONHOME

unset $PYTHONPATH

或者退出当前登陆,重新建立ssh连接。


以上是关于Vue+TypeScript 实际开发项目 避坑指南的主要内容,如果未能解决你的问题,请参考以下文章

分享 15 个 Vue3 全家桶开发的避坑经验

基于 Vue3 和 TypeScript 项目大量实践后的思考

用TypeScript开发Vue——如何通过vue实例化对象访问实际ViewModel对象

避坑+解决方案:Ant-Design-Vue 走马灯Carousel 数据绑定问题

基于 Vue3 和 TypeScript 项目大量实践后的思考

基于 Vue3 和 TypeScript 项目大量实践后的思考