实习记录2

1.flowable框架参数传递大概流程
通过传递xml,传递到后端,然后后端去解析请添加图片描述
请添加图片描述
请添加图片描述

2.vue封装组件
在 Vue.js 中创建可复用的自定义组件是一个常见的需求,这样可以提高代码的复用性和可维护性。下面是一个简单的步骤指南,帮助你创建一个自定义组件,并在其他 Vue 文件中使用它,同时还能传递参数。

步骤 1: 创建自定义组件

假设你想创建一个名为 MyCard 的组件,它可以展示一些信息,并且可以接受标题和内容作为参数。在你的项目源码目录下,创建一个新的 Vue 文件,例如 MyCard.vue

Vue

<!-- MyCard.vue -->
<template>
  <div class="card">
    <h2>{{ title }}</h2>
    <p>{{ content }}</p>
  </div>
</template>

<script>
export default {
  name: 'MyCard',
  props: {
    title: {
      type: String,
      default: 'Default Title'
    },
    content: {
      type: String,
      default: 'Default Content'
    }
  }
}
</script>

<style scoped>
.card {
  border: 1px solid #ccc;
  padding: 20px;
  margin-bottom: 20px;
}
</style>

这里我们定义了一个 MyCard 组件,它有一个简单的 HTML 结构,并且可以通过 props 接收外部传递进来的 titlecontent 数据。

步骤 2: 注册并使用组件

接下来,你可以在任何 Vue 文件中注册并使用 MyCard 组件。有两种注册方式:局部注册和全局注册。

全局注册

main.js 或者 main.ts 文件中全局注册组件,这样所有 Vue 文件都可以直接使用它而不需要再次注册。

Javascript

// main.js
import Vue from 'vue';
import App from './App.vue';
import MyCard from './components/MyCard.vue';

Vue.component('MyCard', MyCard);

new Vue({
  render: h => h(App),
}).$mount('#app')
局部注册

在具体的 Vue 文件中局部注册组件,这样只有这个文件才能使用它。

Vue

<template>
  <div id="app">
    <MyCard title="Hello World" :content="message" />
  </div>
</template>

<script>
import MyCard from './components/MyCard.vue';

export default {
  name: 'App',
  components: {
    MyCard
  },
  data() {
    return {
      message: 'Welcome to Vue.js!'
    };
  }
};
</script>

在上述示例中,我们在 App.vue 文件中导入了 MyCard 并在局部注册了它。然后在模板中使用 <MyCard> 标签,并通过属性绑定的方式传递了 titlecontent

总结

通过以上步骤,你可以轻松地在 Vue.js 项目中创建和使用自定义组件,同时还能灵活地传递参数。这不仅提高了代码的复用性,还让组件之间的数据交互更加清晰和简洁。

3.vue watch
watch 是 Vue.js 中用于响应数据变化的一种方式。当你有一个数据属性需要在它的值改变时执行一些副作用(如数据处理、UI 更新、异步请求等),watch 提供了一种非常方便的方式来处理这种场景。

在 Vue 中,watch 是一个对象,它的键是你想要观察的响应式属性的名称,而值是一个函数或对象。这个函数或对象定义了当被观察的属性发生变化时应该执行的代码。

基础用法

Javascript

export default {
  data() {
    return {
      message: 'Hello Vue!'
    };
  },
  watch: {
    message(newVal, oldVal) {
      console.log(`message changed from ${oldVal} to ${newVal}`);
    }
  }
};

在这个例子中,每当 message 的值发生改变,watch 中定义的函数就会被调用,函数接收到新的值 (newVal) 和旧的值 (oldVal)。

深度观察

如果需要观察嵌套属性的变化,可以使用深度观察。这可以通过在 watch 对象中将属性值设置为包含 deep: true 的对象来实现。

Javascript

export default {
  data() {
    return {
      user: {
        name: 'John Doe'
      }
    };
  },
  watch: {
    user: {
      handler(newVal, oldVal) {
        console.log(`User's name changed from ${oldVal.name} to ${newVal.name}`);
      },
      deep: true
    }
  }
};

在这个例子中,user 对象的任何属性变化都会触发 handler 函数。

立即执行

你还可以让 watch 函数在组件初始化时立即执行一次,这可以通过在 watch 对象中将属性值设置为包含 immediate: true 的对象来实现。

Javascript

export default {
  data() {
    return {
      count: 0
    };
  },
  watch: {
    count: {
      handler(newVal, oldVal) {
        console.log(`Count is now ${newVal}`);
      },
      immediate: true
    }
  }
};

在这个例子中,handler 函数不仅在 count 发生变化时调用,而且在组件初始化时也会调用一次。

总的来说,watch 是 Vue 中一种非常强大的特性,它允许你对数据的变化做出反应,执行特定的操作,这对于构建响应式和动态的 UI 非常有用。

4.管理员主动切换下属账号思路:
后端直接生成token传递过来,跳过密码对比步骤。前端重设token后刷新页面

5.VForm开关设定控件显示或隐藏
请添加图片描述

6.console.log失效
不知道,换console.info

7.vform结合msg,弹窗增加扩展性
示例代码:(放到vform的事件属性中)
MailGroupSelector是我自己全局封装的一个组件
emailGroupSelectShow是需要回显的输入框
getSelectRow是在组件中写的一个获取选取数据的方法。(因为我这段业务是为了弹窗展示一系列可选项,然后选择后回显到输入框)
基本上只需要替换自封装组件和输入框唯一名称(VForm可视化面板中设定),就能用了

let h = this.$createElement;
let input = this.getWidgetRef("emailGroupSelectShow");
// 使用ref属性给MailGroupSelector组件一个引用名
let mailGroupSelectorRef = 'mailGroupSelectorRef';

// 确保此方法在组件的mounted钩子或之后被调用
this.$nextTick(() => {
  this.$msgbox({
    title: '邮件组选择',
    message: h('div', null, [
      h('MailGroupSelector', { ref: mailGroupSelectorRef })
    ]),
    customClass: 'winClass',
    showCancelButton: true,
    confirmButtonText: '确定',
    cancelButtonText: '取消',
    beforeClose: (action, instance, done) => {
      if (action === 'confirm') {
        // 使用Vue.nextTick()确保在DOM更新后访问$refs
        this.$nextTick().then(() => {
          if (this.$refs[mailGroupSelectorRef]) {
            this.$refs[mailGroupSelectorRef].getSelectRow().then(result => {
              // 这里你可以处理getSelectRow返回的结果
              console.log('Selected rows:', result);
              input.setValue(result.dictValue);

              // 一旦处理完成,立即关闭对话框
              done();
            }).catch(error => {
              // 处理任何可能的错误
              console.error('Error getting selected rows:', error);
              done();
            });
          } else {
            console.error('MailGroupSelector组件未找到');
            done();
          }
        });
      } else {
        done();
      }
    }
  })
});

8.mybiats 延迟加载、associate、collection
教程

  • 14
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值