V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
maymay5
V2EX  ›  分享创造

我做了一个闭源的 AIBot(简称:所有生成式 AI 集成套壳),又正在做一个开源的

  •  
  •   maymay5 · 274 天前 · 2945 次点击
    这是一个创建于 274 天前的主题,其中的信息可能已经有所发展或是发生改变。

    闭源项目的网站: https://maymay5.com

    882f74be9380bb3b4f68a71de53ad533.png

    为啥闭源,因为代码可读性是没有可读性,功能多,分布杂,逻辑绕 实在是没脸开源

    开源的版本长这样(还在努力开发中。。。)

    0106024bbfae5e59ac7271bfeac0f4d2.png

    Q:开源版本很高级吗?

    A:其实也很 low ,只是框架升级到了.net 6 ,后端用了还算标准的依赖注入,中间件等开发模式,ORM 用了较通用的 EF Core

    Q:这是新版本的一个较有代表性的前端代码(为什么有代表性,因为 90%的界面内容都是这样的渲染模式),就可以看出我的前端水平等于没有水平,所以我想知道,这样的开源项目,真的会有人想去部署吗???

      function getWorkShopPlugins(type) {
        var name = $('#searchKey').val();
        if (type == 'init') {
            page = 1;
            pageSize = 10;
        }
        if (type == 'loadmore') {
            page++;
        }
        var data = {
            name: name,
            page: page,
            pageSize: pageSize
        };
        $.ajax({
            type: 'Post',
            url: '/WorkShop/GetWorkShopPlugins',
            data: data,
            success: function (res) {
                if (res.success) {
                    var html = '';
                    for (var i = 0; i < res.data.length; i++) {
                        var item = res.data[i];
                        html += '<div class="col-lg-3 col-md-6 col-sm-12 mb-4 grid-item">';
                        html += '<div class="card h-100">';
                        html += '<img class="card-img-top" style="width: 50px;margin:10px auto;" src="' + item.pavatar + '" alt="插件名称 1">';
                        html += '<div class="card-body">';
                        html += '<h5 class="card-title">' + item.pnickname + '</h5>';
                        html += '<p class="card-text">' + item.pfunctioninfo + '</p>';
                        html += '<p class="card-text"><span>价格:</span><span style="color:#f2c044" class="plugin_price">' + item.pluginprice + '</span></p>';
                        html += '<div class="d-flex justify-content-center">';
                        html += `<a href="#" class="btn btn-primary" style="margin-right:10px;" onclick="insertPlugin(` + item.id + `,'` + item.pluginprice + `')">安装</a>`;
                        html += '<a href="#" class="btn btn-secondary" onclick="seePlugin(' + item.id + ')">查看</a>';
                        html += '</div>';
                        html += '</div>';
                        html += '</div>';
                        html += '</div>';
                    }
                    if (type == 'loadmore') {
                        $('#masonry-layout').append(html);
                        if (res.data.length < pageSize) {
                            balert('没有更多了', "info", false, 1500);
                            page--;
                        }
                    } else
                        $('#masonry-layout').html(html);
                    var elem = document.querySelector('#masonry-layout');
                    new Masonry(elem, {
                        // 选项
                        itemSelector: '.grid-item',
                        columnWidth: '.grid-item',
                        percentPosition: true
                    });
                }
            }
        });
    }
    
    10 条回复    2024-02-11 17:28:10 +08:00
    Jirajine
        1
    Jirajine  
       274 天前
    为啥要手动拼接 html 字符串啊,这不是水平的问题,能用这种方式糊出来应用说明你的前端水平不会有问题,用个框架是顺手拈来的事。就算你不喜欢那几个主流框架,推荐试试 lit 或者 apline 这种比较 kiss 的,很适合平替 jquery 。既然你后端都用 dotnet 了,blazor 一把梭也行。
    maymay5
        2
    maymay5  
    OP
       274 天前
    @Jirajine 感谢,我去了解一下,我一直用 jquery 糊,感觉很直观。blazor 太难看了而且不好更新
    SillyGod
        3
    SillyGod  
       273 天前 via Android
    你这计费为什么不把输入输出分开呢?
    (否则,你 32k 那还解释半天)
    maymay5
        4
    maymay5  
    OP
       273 天前
    @SillyGod 闭源版本的用户 90%都是程序员,对于 api 其实都很了解的,加入解释是因为后来有一部分非程序员用户流入,一直没去弄,因为目前来看我的用户对于这个定价不关心,因为个人中心有计费详情,他们测试一下就能估算出消耗
    SillyGod
        5
    SillyGod  
       273 天前 via Android
    @maymay5
    也就是说你 input output 是一个费率来计算的喽?
    maymay5
        6
    maymay5  
    OP
       273 天前
    @SillyGod 是的,但是 input 计算出 token 后会去掉 80%,其实依旧还是 input 便宜的
    SillyGod
        7
    SillyGod  
       272 天前 via Android
    @maymay5
    我最开始的意思的重点在于
    “ 为什么你不把 input output 分开算呢? ”
    合在一起算才导致“ 解释 xxx + 80%这个算法 ”
    SillyGod
        8
    SillyGod  
       272 天前 via Android
    @SillyGod
    本来 OpenAI 的策略就是分开算,你分开算对用户、对开发都很方便,不是很理解为什么非得合起来。(这跟用户懂不懂就没关系了,我懂 oai 的策略反而好奇为什么你不分开算)
    maymay5
        9
    maymay5  
    OP
       272 天前 via iPhone
    @SillyGod 用这种更绕的计算方式,那就是商务层面的考虑了,因为低价转发 api 迟早是要消失的,输入输出同价,我只需要很轻微的百分比调整就能控制价格,token 消耗百分比上涨 0.5%和价格上涨 0.5 元,用户普遍更接受前者,就像三大运营商的文字游戏
    SillyGod
        10
    SillyGod  
       272 天前 via Android
    @maymay5
    hh,果然如此
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2373 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 00:18 · PVG 08:18 · LAX 16:18 · JFK 19:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.