odoo中domain用法整理

1.在py文件中的many2one字段中体现

如果需要筛选many2one这张表中的数据,
domain="[(‘id’, ‘=’, supplier)]"

supplier = fields.Many2one('bs.supplyer', string='供应商')
supplier_client = fields.Many2one('bs.supply.entrust', string='被委托人',domain="[('id', '=', supplier)]")

id是‘bs.supply.entrust’这张表的id,supplier则是本身选中供应商的id

2.在xml文件中应用domain筛选

<field name="supplier" string="供应商" required="1" domain="[('is_hq', '!=', True)]"
                                       attrs="{'readonly': [('status', '!=', '7')]}"/>

1)xml文件中的required和readonly优先级比py文件高,如果并不是所有用到该表的文件字段都要必填或者只读,可以考虑在xml文件中添加required和readonly

2)attrs属性,表示字段在status=‘7’情况下只读

3)domain筛选的是is_hq为true的数据

3.在py文件的方法中添加domain

1)例如,我们想筛选那些没有添加过的数据

goodsid = fields.Many2one('bs.ky.goods', string='商品名称', search_able=True)
    

search_able = True 表示可以在页面的筛选中找到
odoo中domain用法整理_第1张图片
2)过滤已经选择过的商品id

@api.onchange('goodsid')
    def check_goodsid(self):
        ids = []
        deducation = self.env['order.goods.deducation'].search([])
        for i in deducation:
            ids.append(i.goodsid.id)
        return {
            'domain': {
                'goodsid': [('id', 'not in', ids)]
            }
        }

备注:若以后有关于goodsid的操作不起作用时,可以查查是不是筛选的方法有问题,比如继承的时候,需要把方法也重写

你可能感兴趣的:(odoo学习)