ABAP ALV最常规写法及常用功能详解

 更新时间:2022年09月09日 10:24:39   作者:百里落云  
这篇文章主要为大家介绍了ABAP ALV最常规写法及常用功能详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

先导

记得刚学ABAP的时候问这问那,问东问西,常常一个可能不怎么用的东西,扣了好久好久.群里的大佬就说,学那么多没必要,以后是会天天写ALV , 讲真 因为 SAP 很多东西都已经通过配置就可以实现, 我们还真就是做表单相关的东西比较多,不能说全部,也是大部分. 好巧今天看到群友问ALV 相关的内容,这里整理一下,希望帮助更多的人 ヾ(◍°∇°◍)ノ゙.

流程顺序

开发ALV的基本流程:

第1步:声明变量

       定义ALV所要用到的类型池:TYPE-POOLS: SLIS 

       针对ALV的控制信息数据(Layout & Fieldcat)

第2步:定义内表
       存放自定义数据文件的数据,以及在ALV中显示

第3步:读取数据

       读取数据存放至Internal Table

第4步:ALV格式控制

       建立ALV显示样式(layout)和显示字段清单(Field Catalogs)

第5步:定义事件

       建立事件清单(Event Catalogs)

第6步:显示ALV

       调用ALV Function Module

第7步:用户事件

       定义User按键处理事件

普通的ALV的流程如上图,包含所有常规流程.本质上是展示数据的报表. 以及常用语法的熟练使用,数据转换,逻辑计算等.

ALV 界面介绍

ALV组成3大部分

工具栏

标题栏

显示数据的网格控制器 (必要时可以隐藏工具栏和标题栏)

ALV 开发注意事项

注意事项:
1、在ALV中,需要注意所有需要显示的列,都必须在相应的内表中有对应的字段, 字段名字不能写错。
2、在SAP ABAP程序中,字符串的大小写很重要,在单引号包围的字符串中, 一般来说都应该用大写,特别是在调用一些系统的方法时传入字符串参数时。 
3、传入到ALV中的列对应的字段名称也必须使用大写字母,否则数据不会显示出来。 
4、使用宏定义或者子例程可以减少代码量,并且尽可能实现代码的复用。
5、注意在FORM里定义的变量在离开FORM后,就会被系统释放掉,回收内存空间。

ALV 基本参数

ALV 对象参数

ALV开发中两个重要的对象——FIELDCAT和LAYOUT:
    在调用ALV的函数中,除了定义所输出使用的内表之外,
    还有两个部分是必需确认的:列栏位属性和布局属性。
列栏位属性FIELDCAT :
    设置输出中具体字段的名称、类型、格式等属性;
    对于系统结构表,函数可参照此结构自动创建列属性,可以没有调用列栏位属性
布局属性LAYOUT:
    设置输出ALV列表的整体布局的属性,如输出字段的颜色、表格中的线条等。
    没有调用布局属性时,系统按默 认布局输出,不做任何调整。
两对象同属于类型组SLIS,在ALV开发中必须声明类型组SLIS

ALV 参数控制Layout

布局控制[layout]
 布局是用来控制整个ALV的一个布局,比如ALV的标题,是否可编辑,行颜色,列颜色.
 参照ALV的控制结构[LVC_S_LAYO],以后的例子我将详细介绍如何设置行颜色和列颜色.
 详细的结构说明(注意这些字段的取值,单引号内,' '空格代表否,'X' 代表是)
 
   字段名           描述             Value range
   CWIDTH_OPT          最优化宽度            SPACE, 'X'
   SMALLTITLE           小标题             SPACE, 'X'
   GRID_TITLE         标题,在网格和工具条之间       最长70个字符
   NO_HEADERS          列标题隐藏              SPACE, 'X'
   NO_HGRIDLN          隐藏水平线             SPACE, 'X'
   NO_MERGING          禁用单元格合并           SPACE, 'X'
   NO_ROWMARK    禁用系统自带的行选择'X'为D和A的时候隐藏     SPACE, 'X'
   NO_TOOLBAR          隐藏工具条             SPACE, 'X'
   NO_VGRIDLN          隐藏垂直线             SPACE, 'X'
   SEL_MODE           选择模式             SPACE, 'A', 'B', 'C', 'D'
   EXCP_CONDS           合计例外             SPACE, 'X'
   EXCP_FNAME         字段名称带有例外编码        最长30个字符
   EXCP_LED           例外作为 LED            SPACE, 'X'
   EXCP_ROLLN         例外文档的数据元素          SPACE, 'X'
   CTAB_FNAME      带有复杂单元格颜色编码的字段名称     最长30个字符
   INFO_FNAME     带有简单行彩色代码的字段名称        最长30个字符
   ZEBRA        可选行颜色,如果设置了,出现了间隔色带   SPACE, 'X'
   NO_TOTLINE          没有总计             SPACE, 'X'
   NUMC_TOTAL        可以对NUMC字段进行合计        SPACE, 'X'
   TOTALS_BEF     总计输出在第一行,小计在新的值之前      SPACE, 'X'
   STYLEFNAME     设置单元格,比如PUSHBUTTON          最长30个字符

ALV 参数控制Fieldcat

 Fieldcat
 data: fieldcat type slis_t_fieldcat_alv with header line.
 it_fieldcat  =  fieldcat[]
 属性
  (用来定义表单中的各个列的相关信息)
   Fieldcat-col_pos = n.            输出列
   Fieldcat-tabname = ‘FIELDNAME’.      对应的内表字段名
   Fieldcat-seltext_s/m/l = ‘列名’.     输出列文本( _s:短文本  _l:长文本)
   Fieldcat-emphasize = ‘CX10’.    带有颜色的高亮列(其中X=(1-7)颜色同format)
   Fieldcat-hotspot = ‘X’.       作为热点显示可触发鼠标触发事件
   Fieldcat-currency = ‘CURRKEY’.   表 TCURX 中的货币名称
   Fieldcat-quantity(3)            计量单位
   Fieldcat-qfieldname           参考计量单位的字段名称
   Fieldcat-round = n.           四舍五入至小数位数下n 位
   Fieldcat-exponent = n.         浮点数的幂指数为n
   Fieldcat-key = ‘X’.           关键字段
   Fieldcat-icon = ‘X’.          作为图标输出
   Fieldcat-symbol = ‘X’.        输出作为符号
   Fieldcat-checkbox = ‘X’.      作为复选框输出
   Fieldcat-just = SPACE, 'R', 'L', 'C'.   对齐方式
   Fieldcat-lzero = ‘X’.          输出前导零
   Fieldcat-no_sign = ‘X’.        输出抑制符号
   Fieldcat-no_zero = ‘X’.        为输出隐藏零
   Fieldcat-edit_mask = SPACE, mask..  输出为mask的模式
   Fieldcat-fix_column = ‘X’.      固定列
   Fieldcat-do_sum = ‘X’.        总计列值总和
   Fieldcat-no_out = ‘X’.         列不输出
   Fieldcat-tech = ‘X’.         该字段为技术字段
   Fieldcat-outputlen = n        列的字符宽度为n
   Fieldcat-decimals_out = n     能控制小数点的位数为n 
   Fieldcat-datatype = C,I,N…   定义数据类型

ALV定义事件

* 建立事件清单(Event Catalogs)
*需定义事件块,否则出错
eventcat_ln-name  =  'TOP_OF_PAGE'.eventcat_ln-form  =  'PAGE_HEADER'.
APPEND  eventcat_ln  TO  eventcat.
事件块:
FORM PAGE_HEADER.
ENDFORM.

ALV DEMO

1:声明alv

代码

REPORT YALVDEMO1.
*第一步 :声明alv相关 变量
TYPE-POOLS:SILS.   "引入slis 包 定义 使用专门alv
data:LT_FIELDCAT  TYPE SLIS_T_FIELDCAT_ALV,   "存储fieldcat 内表, 列表标签相关
      LS_FIELDCAT  TYPE SLIS_FIELDCAT_ALV,
*WA_FIELDCAT  TYPE SLIS_FIELDCAT_ALV,      "定义使用工作区
*ls_fieldcat   like LINE OF     LT_FIELDCAT,
     LS_LAYOUT    TYPE SLIS_LAYOUT_ALV,     "ALV格式控制的结构体
     LT_EVENT TYPE slis_T_event  ,  " 事件的内表
     LS_EVENT TYPE slis_alv_event.  "事件的工作区
DATA:  pgm  LIKE  sy-repid.
DATA LT_SORT TYPE SLIS_T_SORTINFO_ALV .
DATA WA_SORT TYPE SLIS_SORTINFO_ALV.
DATA LS_SETTING TYPE LVC_S_GLAY.
DATA : LV_COLPOS TYPE INT2 .

着重解释

主要是生命变量
引入slis 包,   
建立内表,
定义变量

2:定义内表

代码

*第二部:定义内表
*定义类型.
TYPES:BEGIN OF ty_alvshow,
  CARRID TYPE SPFLI-CARRID,  "航线代码
  CITYFROM  type SPFLI-CITYFROM , "起飞城市.
  CITYTO TYPE SPFLI-CITYTO  , "目标城市
  FLDATE  type SFLIGHT-FLDATE  ,"起飞时间
  PLANETYPE TYPE  SFLIGHT-PLANETYPE ,"飞机类型
  SEATSMAX TYPE SFLIGHT-SEATSMAX ,"飞机容量
  END OF ty_alvshow.
*定义内表和工作区
data : LT_ALVSHOW TYPE TABLE OF ty_alvshow,  "定义内表
       WA_ALVSHOW  TYPE ty_alvshow.

着重解释

类型 可以直接写入字段类型中的 类型
或者干脆 直接写表名-字段  也可以. 

3:读取数据

代码

*第三部:读取数据
select
a~CARRID  CITYFROM
CITYTO FLDATE
PLANETYPE SEATSMAX
FROM spfli as a inner  join  SFLIGHT as  b on a~CARRID = b~CARRID
  into  table LT_ALVSHOW   "内表需要增加table
  UP TO 10 ROWS.

4:字段配置 ALV格式控制.

代码

*第四部: ALV 的格式控制. layout
LS_LAYOUT-zebra = 'X'. "列输出位置
LS_LAYOUT-detail_popup = 'X' ."是否弹出详细明细窗口
LS_LAYOUT-detail_TITLEBAR = '详细信息'.
LS_LAYOUT-f2code = '&ETA' . "设置触发弹窗信息功能
LS_LAYOUT-colwidth_optimize = 'X' . "设置自动优化列宽.
"fieldcat 界面配置
lv_colpos = 1  . "字段显示为第几行
ls_FIELDCAT-fieldname  = 'CARRID'.   "那个字段
LS_FIELDCAT-col_pos = LV_COLPOS.
LS_FIELDCAT-key  = 'X'.
LS_FIELDCAT-DATATYPE = 'CHAR' .
LS_FIELDCAT-OUTPUTLEN = '10'.
LS_FIELDCAT-SELTEXT_M = '飞机id'.
APPEND LS_FIELDCAT to LT_FIELDCAT.
clear LS_FIELDCAT .
"fieldcat 界面配置
lv_colpos = LV_COLPOS + 1  . "字段显示为第几行
ls_FIELDCAT-fieldname  = 'CITYFROM'.   "那个字段
LS_FIELDCAT-col_pos = LV_COLPOS.
LS_FIELDCAT-key  = 'X'.
LS_FIELDCAT-DATATYPE = 'CHAR' .
LS_FIELDCAT-OUTPUTLEN = '30'.
LS_FIELDCAT-SELTEXT_M = '出发城市'.
APPEND LS_FIELDCAT to LT_FIELDCAT.
clear LS_FIELDCAT .
"fieldcat 界面配置
lv_colpos = LV_COLPOS + 1  . "字段显示为第几行
ls_FIELDCAT-fieldname  = 'CITYTO'.   "那个字段
LS_FIELDCAT-col_pos = LV_COLPOS.
LS_FIELDCAT-key  = 'X'.
LS_FIELDCAT-DATATYPE = 'CHAR' .
LS_FIELDCAT-OUTPUTLEN = '30'.
LS_FIELDCAT-SELTEXT_M = '到达城市'.
APPEND LS_FIELDCAT to LT_FIELDCAT.
clear LS_FIELDCAT .
"fieldcat 界面配置
lv_colpos = LV_COLPOS + 1  . "字段显示为第几行
ls_FIELDCAT-fieldname  = 'FLDATE'.   "那个字段
LS_FIELDCAT-col_pos = LV_COLPOS.
LS_FIELDCAT-key  = 'X'.
LS_FIELDCAT-DATATYPE = 'DATS' .
LS_FIELDCAT-OUTPUTLEN = '8'.
LS_FIELDCAT-SELTEXT_M = '到达时间'.
APPEND LS_FIELDCAT to LT_FIELDCAT.
clear LS_FIELDCAT .
"fieldcat 界面配置
lv_colpos = LV_COLPOS + 1  . "字段显示为第几行
ls_FIELDCAT-fieldname  = 'PLANETYPE'.   "那个字段
LS_FIELDCAT-col_pos = LV_COLPOS.
LS_FIELDCAT-key  = 'X'.
LS_FIELDCAT-DATATYPE = 'char' .
LS_FIELDCAT-EDIT = 'X'.
LS_FIELDCAT-OUTPUTLEN = '20'.
LS_FIELDCAT-SELTEXT_M = '飞机类型'.
APPEND LS_FIELDCAT to LT_FIELDCAT.
clear LS_FIELDCAT .
"fieldcat 界面配置
*lv_colpos = LV_COLPOS + 1  . "字段显示为第几行
*ls_FIELDCAT-fieldname  = 'SEATSMAX'.   "那个字段
*LS_FIELDCAT-col_pos = LV_COLPOS.
*LS_FIELDCAT-key  = 'X'.
*LS_FIELDCAT-DATATYPE = 'int4' .
*LS_FIELDCAT-OUTPUTLEN = '20'.
*LS_FIELDCAT-SELTEXT_M = '飞机容量'.
*APPEND LS_FIELDCAT to LT_FIELDCAT.
*clear LS_FIELDCAT .
"fieldcat 界面配置
lv_colpos = LV_COLPOS + 1  . "字段显示为第几行
ls_FIELDCAT-fieldname  = 'SEATSMAX'.   "那个字段
LS_FIELDCAT-col_pos = LV_COLPOS.
LS_FIELDCAT-ref_fieldname = 'SFLIGHT' .
LS_FIELDCAT-do_sum = 'X' .
LS_FIELDCAT-SELTEXT_M = '飞机容量'.
APPEND LS_FIELDCAT to LT_FIELDCAT.
Clear LS_FIELDCAT .

着重解释

首先需要配置layout 相关内容

在配置每个字段的fieldcat .

注意:显示列数要设置逐级增加,并且要把内表数据覆盖内表 ,并清空内表数据.

5:定义事件

代码

LS_EVENt-name  = 'USER_COMMAND' ."用户响应事件
LS_EVENT-FORM = 'FORM_USER_COMMAND' .
APPEND LS_EVENT TO LT_EVENT .
CLEAR LS_EVENT .
LS_EVENT-name  = 'TOP_OF_PAGE' ."显示标题
LS_EVENT-form = 'FORM_TOP_OF_PAGE' .
APPEND LS_EVENT TO LT_EVENT .
CLEAR LS_EVENT .
LS_EVENt-name  = 'PF_STATUS_SET' ."显示状态栏
LS_EVENT-FORM = 'FORM_PF_STATUS_SET' .
APPEND LS_EVENT TO LT_EVENT .
CLEAR LS_EVENT .

6:排序(常用功能)

代码

*------第六步  排序
WA_SORT-fieldname = 'SEATSMAX'  .
WA_SORT-DOWN = 'X'.
APPEND WA_SORT TO LT_SORT .
CLEAR  wa_sort .   "清空工作区

7:显示alv数据

操作

光标要留在数据的位置,然后点 模式-->调用功能输入-->REUSE_ALV_GRID_DISPLAY
-->按回车.-->自动生成代码

代码

*第七部分显示alv
LS_SETTING-EDT_CLL_CB = 'X' .  "编辑单元格之后, 返回给程序编辑后的值.
pgm = sy-repid.  "回调对象
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
  EXPORTING
*   I_INTERFACE_CHECK        = ' '
*   I_BYPASSING_BUFFER       = ' '
*   I_BUFFER_ACTIVE          = ' '
   I_CALLBACK_PROGRAM       = pgm
   I_CALLBACK_PF_STATUS_SET = 'PF_STATUS_SET'
   I_CALLBACK_USER_COMMAND  = 'USER_COMMAND'
  I_CALLBACK_TOP_OF_PAGE   = 'TOP_OF_PAGE'
*   I_CALLBACK_HTML_TOP_OF_PAGE       = ' '
*   I_CALLBACK_HTML_END_OF_LIST       = ' '
*   I_STRUCTURE_NAME         =
*   I_BACKGROUND_ID          = ' '
*   I_GRID_TITLE  =
   I_GRID_SETTINGS          =  LS_SETTING  "编辑单元格之后, 返回给程序编辑后的值.
    IS_LAYOUT     = LS_LAYOUT
    IT_FIELDCAT   = LT_FIELDCAT
*   IT_EXCLUDING  =
*   IT_SPECIAL_GROUPS        =
   IT_SORT       = LT_SORT
*   IT_FILTER     =
*   IS_SEL_HIDE   =
*   I_DEFAULT     = 'X'
*   I_SAVE        = ' '
*   IS_VARIANT    =
    IT_EVENTS     = LT_EVENT
*   IT_EVENT_EXIT =
*   IS_PRINT      =
*   IS_REPREP_ID  =
*   I_SCREEN_START_COLUMN    = 0
*   I_SCREEN_START_LINE      = 0
*   I_SCREEN_END_COLUMN      = 0
*   I_SCREEN_END_LINE        = 0
*   I_HTML_HEIGHT_TOP        = 0
*   I_HTML_HEIGHT_END        = 0
*   IT_ALV_GRAPHICS          =
*   IT_HYPERLINK  =
*   IT_ADD_FIELDCAT          =
*   IT_EXCEPT_QINFO          =
*   IR_SALV_FULLSCREEN_ADAPTER        =
* IMPORTING
*   E_EXIT_CAUSED_BY_CALLER  =
*   ES_EXIT_CAUSED_BY_USER   =
  TABLES
    T_OUTTAB      = LT_ALVSHOW
  EXCEPTIONS
    PROGRAM_ERROR = 1
    OTHERS        = 2.
IF SY-SUBRC <> 0.
* Implement suitable error handling here
ENDIF.

解释

1:生成的代码都是注释的

2:选择使用的解除注释并赋值

8:按钮操作标题栏等配置

代码

*按钮 gui
FORM FORM_PF_STATUS_SET   USING RT_EXTAB TYPE SLIS_T_EXTAB   .
  SET PF-STATUS 'YALVDEMO1_GUI'.
ENDFORM.
*标题
FORM  FORM_TOP_OF_PAGE.
*定义数据 内表和工作区
  DATA LT_COMMENTARY TYPE SLIS_T_LISTHEADER.
  DATA WA_COMMENTARY TYPE SLIS_LISTHEADER.
  WA_COMMENTARY-TYP = 'H' .
  WA_COMMENTARY-INFO = '飞机飞行清单' .
  APPEND WA_COMMENTARY TO LT_COMMENTARY .
  WA_COMMENTARY-TYP = 'S' .
  WA_COMMENTARY-INFO = '中号标题' .
  APPEND WA_COMMENTARY TO LT_COMMENTARY .
  CALL FUNCTION 'REUSE_ALV_COMMENTARY_WRITE'
    EXPORTING
      IT_LIST_COMMENTARY = LT_COMMENTARY.
*   I_LOGO                   =
*   I_END_OF_LIST_GRID       =
*   I_ALV_FORM               =
ENDFORM.
*用户操作按钮
FORM  FORM_USER_COMMAND  USING R_UCOMM LIKE SY-UCOMM
     RS_SELFIELD TYPE SLIS_SELFIELD  .
data : lt_SFLIGHT  TYPE table of SFLIGHT ,   "内表
    wa_SFLIGHT type  SFLIGHT.  "工作区
     IF R_UCOMM = 'ZYDD1' .
       MESSAGE '你触发了按钮' TYPE 'I'.
    ELSEIF R_UCOMM = 'Z_SAVE1' .
select  *  from SFLIGHT   into table  lt_SFLIGHT
        for ALL ENTRIES IN LT_ALVSHOW
  where CARRID = lt_alvshow-CARRID .
          ENDIF .
loop at lt_SFLIGHT into wa_SFLIGHT .   "从工作区取数 循环
READ TABLE LT_ALVSHOW into WA_ALVSHOW WITH KEY CARRID =  wa_SFLIGHT-CARRID .
if sy-SUBRC = 0 .
*MESSAGE  WA_ALVSHOW-PLANETYPE  TYPE 'I'.
  wa_SFLIGHT-PLANETYPE = WA_ALVSHOW-PLANETYPE .
  MODIFY  lt_SFLIGHT from  wa_SFLIGHT.  "内表更新
  ENDIF .
  CLEAR wa_SFLIGHT .
  CLEAR WA_ALVSHOW.
ENDLOOP.
update  SFLIGHT from table   lt_SFLIGHT.
  if sy-subrc = 0 .
    commit work .  "数据库提交
        MESSAGE '保存成功' TYPE 'I'.
    else .
      ROLLBACK work .
              MESSAGE '保存失败' TYPE 'I'.
      ENDIF.
ENDFORM  .

总结

这个demo 是最简单的DEMO 使用的是 系统内置表(飞机表) , 其中包含了用户操作,排序,求和等常规用户操作和界面优化 .

常规语法的通俗使用. 此demo还可以进一步优化,把常规重复性操作写入到函数或者宏中,后续会发更优化版本.

作为入门demo 可以让你充分了解ALV ,及ALV 常规用到的属性.

以上就是ABAP ALV最常规写法及常用功能详解的详细内容,更多关于ABAP ALV 写法功能的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:

相关文章

  • 使用Windows自带的IIS服务搭建本地站点并远程访问的操作方法

    使用Windows自带的IIS服务搭建本地站点并远程访问的操作方法

    在Windows系统中实际上集成了建立网站所必须的软件环境,今天就让我们来看看,如何使用Windows自带的网站程序建立网站吧,感兴趣的朋友一起看看吧
    2023-12-12
  • JetBrains Fleet 初体验

    JetBrains Fleet 初体验

    本文主要介绍了JetBrains Fleet 初体验,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • kettle在windows上安装配置与实践案例

    kettle在windows上安装配置与实践案例

    Kettle是一款开源的ETL工具,纯java编写,可以在Window、Linux、Unix上运行,绿色无需安装,数据抽取高效稳定,这篇文章主要介绍了kettle在windows上安装配置与实践案例,需要的朋友可以参考下
    2022-11-11
  • vscode调试launch.json常用格式完整的案例

    vscode调试launch.json常用格式完整的案例

    VSCode的launch.json文件是用来配置调试器的,可以设置调试器的启动方式、调试的目标文件、调试的参数,等这篇文章主要给大家介绍了关于vscode调试launch.json常用格式的相关资料,需要的朋友可以参考下
    2024-06-06
  • 程序员面试如何提高面试通过率

    程序员面试如何提高面试通过率

    这篇文章主要给大家介绍了关于程序员面试如何提高面试通过率的相关资料,通过文中介绍的方法可以提高面试概率,让大家尽快找到好工作,需要的朋友可以参考下
    2007-04-04
  • VS CODE 使用SVN插件的方法步骤

    VS CODE 使用SVN插件的方法步骤

    这篇文章主要介绍了VS CODE 使用SVN插件的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • 最新WebStorm2020.2注册码永久激活(激活到2089年)

    最新WebStorm2020.2注册码永久激活(激活到2089年)

    JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。今天给大家带来的是将WebStorm最新版激活至2089年
    2020-09-09
  • vscode安装扩展Volar失败的解决方案

    vscode安装扩展Volar失败的解决方案

    volar扩展的时候,遇到了安装失败的问题,这篇文章主要给大家介绍了关于vscode安装扩展Volar失败的解决方案,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-05-05
  • xmind免费安装使用保姆级教程详解

    xmind免费安装使用保姆级教程详解

    xmind 是一款功能强大、易用且具有丰富资源的思维导图软件,本文将为您介绍 xmind 的安装和使用方法,包括基本功能、高级功能、专业版功能、使用技巧、常见问题等,帮助您快速上手使用 xmind
    2023-04-04
  • 会员下线加积分,实现原理分享(有时间限制)

    会员下线加积分,实现原理分享(有时间限制)

    当某个用户发出一个邀请后,另一个用户通过这个链接进行网站后,为发这个链接的用户加10个积分。
    2011-09-09

最新评论