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
接收外部传递进来的 title
和 content
数据。
步骤 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>
标签,并通过属性绑定的方式传递了 title
和 content
。
总结
通过以上步骤,你可以轻松地在 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();
}
}
})
});